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Preface 


You  have  in  your  hands  a  compact  symbolic  and  numerical  computer  that  will 
facilitate  calculation  and  mathematical  analysis  of  problems  In  a  variety  of 
disciplines,  from  elementary  mathematics  to  advanced  engineering  and 
science  subjects.    Although  referred  to  as  a  calculator,  because  of  its 
compact  format  resembling  typical  hand-held  calculating  devices,  the  hp  48gll 
should  be  thought  of  as  a  graphics/programmable  hand-held  computer. 

The  hp  48gll  can  be  operated  In  two  different  calculating  modes,  the  Reverse 
Polish  Nofation  (RPN)  mode  and  the  Algebraic  (ALG)  mode  (see  page  1-11  In 
user's  guide  for  additional  details).  The  RPN  mode  was  incorporated  into 
calculators  to  make  calculations  more  efficient.  In  this  mode,  the  operands  in 
an  operation  (e.g.,  '2'  and  '3'  In  the  operation  '2+3')  are  entered  Into  the 
calculator  screen,  referred  to  as  the  stack,  and  then  the  operator  (e.g.,  '+'  in 
the  operation  '2+3')  Is  entered  to  complete  the  operation.  The  ALG  mode,  on 
the  other  hand,  mimics  the  way  you  type  arithmetic  expressions  in  paper. 
Thus,  the  operation  '2+3' ,  in  ALG  mode,  will  be  entered  in  the  calculator  by 
pressing  the  keys  '2',  '+',  and  '3',  in  that  order.  To  complete  the  operation 
we  use  the  ENTER  key.  Examples  of  applications  of  the  different  functions 
and  operations  In  this  calculator  are  Illustrated  In  this  user's  guide  In  both 
modes. 

This  guide  contains  examples  that  Illustrate  the  use  of  the  basic  calculator 
functions  and  operations.  The  chapters  in  this  user's  guide  are  organized  by 
subject  in  order  of  difficulty.  Starting  with  the  setting  of  calculator  modes  and 
display  options,  and  continuing  with  real  and  complex  number  calculations, 
operations  with  lists,  vectors,  and  matrices,  detailed  examples  of  graph 
applications,  use  of  strings,  basic  programming,  graphics  programming, 
string  manipulation,  advanced  calculus  and  multivariate  calculus  applications, 
advanced  differential  equations  applications  (Including  Laplace  transform, 
and  Fourier  series  and  transforms),  and  probability  and  statistic  applications. 

For  symbolic  operations  the  calculator  Includes  a  powerful  Computer 
Algebraic  System  (CAS)  that  lets  you  select  different  modes  of  operation,  e.g., 
complex  numbers  vs.  real  numbers,  or  exact  (symbolic)  vs.  approximate 


(numerical)  mode.  The  display  can  be  adjusted  to  provide  textbook-type 
expressions,  which  can  be  useful  when  working  with  matrices,  vectors, 
fractions,  summations,  derivatives,  and  integrals.  The  high-speed  graphics  of 
the  calculator  are  very  convenient  for  producing  complex  figures  in  very  little 
time. 

Thanks  to  the  infrared  port  and  the  RS  232  cable  available  with  your 
calculator,  you  can  connect  your  calculator  with  other  calculators  or 
computers.  The  high-speed  connection  through  infrared  or  RS  232  allows  the 
fast  and  efficient  exchange  of  programs  and  data  with  other  calculators  or 
computers.  The  calculator  provides  a  flash  memory  card  port  to  facilitate 
storage  and  exchange  of  data  with  other  users. 

The  programming  capabilities  of  the  calculator  allow  you  or  other  users  to 
develop  efficient  applications  for  specific  purposes.  Whether  it  is  advanced 
mathematical  applications,  specific  problem  solution,  or  data  logging,  the 
programming  languages  available  in  your  calculator  make  it  into  a  very 
versatile  computing  device. 

We  hope  your  calculator  will  become  a  faithful  companion  for  your  school 
and  professional  applications. 
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A  note  about  screenshots  in  this  guide 

A  screenshot  is  a  representation  of  the  calculator  screen.  For  example,  the 
first  time  the  calculator  is  turned  on  you  get  the  following  screen  (calculator 
screens  are  shown  with  a  thick  border  in  this  section): 


^HD  KYZ  HEX  F.=  'K'  HLG 


EDITlVIEHl  RCL  |  £T0^  IPURGEICLEHR 


The  top  two  lines  represent  the  screen  header  and  the  remaining  area  in  the 
screen  is  used  for  calculator  output. 

Most  screenshots  in  this  guide  were  generated  using  a  computer-based 
emulator  (a  program  that  simulates  the  operation  of  the  calculator  in  a 
computer),  and  are  missing  the  screen  header  lines.  Instead,  they  will  show 
additional  screen  output  area  in  the  location  of  the  header  lines,  as  shown 
below: 


EDIT|VIEH|  RCL  |  £T0^  IPURGEICLEHR 


This  additional  screen  output  area  in  many  screen  shots  in  this  guide  will  not 
show  when  you  try  those  guide's  example  in  your  calculator.  Thus,  while  in 
the  guide  you  may  see  a  screenshot  as  the  following: 


:SIH(£.5) 

,  ^3472 144104 

:-J5.5+LH(2.5) 

2.533039S2043 
:2.3+5.|-2.3l 

13. S 


EDITlVIEHl  RCL  |  £T0^  IPURGEICLEHR 


the  calculator  will  actually  show  the  following  screen: 
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^HD  aiZ  HEX  H=  'K'  HLG 


■J5.5+LH(2.5) 

2.533039S2043 
2.3+5.I-2.3I 

13.8 


EDIT   VIEH    RCL  ^TO^  PURGE  CLEHR 


Notice  that  the  header  lines  cover  the  top  first  and  a  half  lines  of  output  in  the 
calculator's  screen.  Nevertheless,  the  lines  of  output  not  visible  are  still 
available  for  you  to  use.  You  can  access  those  lines  in  your  calculator  by 
pressing  the  up-arrov/  key  ((^^ ),  v/hich  v/ill  allov/  you  to  scroll  down  the 
screen  contents. 


Also,  as  you  perform  the  three  operations  listed  in  the  screenshot,  in  the  order 
shown,  your  screen  will  show  them  occupying  higher  levels  in  the  display  as 
shown  next: 


^HD  KYZ  HEX  F.=  'X'  HLG  ^HD  HYZ  HEX  F.=  'X'  HLG 

iHOHE>   :hohe>  

:SIH(2.5) 

,  ^3472 144104 

:SIH(2.5)  :-J5.5+LH(2.5) 

.593472144104  2.53303932043 


EDIT|VIEH|  RCL  |  £T0^  IPURGEICLEHR  ■  EDIT  |  VIEH  |  RCL  |  £T0^  IPURGEICLEHR 


The  keystrokes  required  to  complete  these  exercises  are  the  following: 

G»D  CXD  CX) 
SD 1^  CU  CD     S  CB  ^  C2D  CD  dD 

The  next  operation, 

OD  a     CS  CX]  CD  CTD  CD  CTJ 

will  force  the  lines  corresponding  to  the  operation  SIN(2.5)  to  move  upwards 
and  be  hidden  by  the  header  lines. 

Many  screenshots  in  this  guide  have  also  been  modified  to  show  only  the 
operation  of  interest.  For  example,  the  screenshot  for  the  operation  SIN(2.5), 
shown  above,  may  be  simplified  in  this  guide  to  look  as: 
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:SIH(2.53 

.598472144104 
ua*innjiiiwMMiiJiianjH»^i 


These  simplifications  of  tfie  screensfiots  are  aimed  at  economizing  output 
space  in  the  guide. 

Be  aware  of  the  differences  between  the  guide's  screenshots  and  the  actual 
screen  display,  and  you  should  have  no  problem  reproducing  the  exercises  in 
this  guide. 
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Chapter  1 
Getting  started 


This  chapter  is  aimed  at  providing  basic  information  in  the  operation  of  your 
calculator.  The  exercises  are  aimed  at  familiarizing  yourself  with  the  basic 
operations  and  settings  before  actually  performing  a  calculation. 

Basic  Operations 

The  following  exercises  are  aimed  at  getting  you  acquainted  with  the 
hardware  of  your  calculator. 

Batteries 

The  calculator  uses  3  AAA  (LR03)  batteries  as  main  power  and  a  CR2032 
lithium  battery  for  memory  backup. 

Before  using  the  calculator,  please  install  the  batteries  according  to  the 
following  procedure. 

To  install  the  main  batteries 

a.  Make  sure  the  calculator  is  off.  Slide  up  the  battery  compartment 
cover  as  illustrated. 


b.  Insert  3  new  AAA  (LR03)  batteries  into  the  main  compartment.  Make  sure 
each  battery  is  inserted  in  the  indicated  direction. 

To  install  the  backup  battery 

a.  Make  sure  the  calculator  is  off.  Press  down  the  holder.  Push  the 
plate  to  the  shown  direction  and  lift  it. 
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Plate  M 

1 — -V  '^-/l^  .  Holder 


1  1 

I  f  1 

b.  Insert  a  new  CR2032  lithium  battery.  Make  sure  its  positive  (+)  side  is 
facing  up. 

c.  Replace  tfie  plate  and  pusfi  it  to  tfie  original  place. 

After  installing  tfie  batteries,  press  [ON]  to  turn  tfie  power  on. 
Warning:  Wfien  tfie  low  battery  icon  is  displayed,  you  need  to  replace  the 
batteries  as  soon  as  possible.  However,  avoid  removing  the  backup  battery 
and  main  batteries  at  the  same  time  to  avoid  data  lost. 


Turning  the  calculator  on  and  off 

The  I  OA'  J  key  is  located  at  the  lower  left  corner  of  the  keyboard.  Press  it  once 
to  turn  your  calculator  on.  To  turn  the  calculator  off,  press  the  red  right-shift 
key  C2D  (first  key  in  the  second  row  from  the  bottom  of  the  keyboard), 
followed  by  the  LowJ  key.  Notice  that  the  LowJ  key  has  a  red  OFF  label 
printed  in  the  upper  right  corner  as  a  reminder  of  the  OFF  command. 

Adjusting  the  display  contrast 

You  can  adjust  the  display  contrast  by  holding  the  L_owj  key  while  pressing  the 
I  +  J  or  [  —  J  keys.  The  I  J(hold)  [  +  J  key  combination  produces  a  darker 
display.  The  (.    J(hold)  (.  —  J  key  combination  produces  a  lighter  display 

Contents  of  the  calculator's  display 

Turn  your  calculator  on  once  more.  The  display  should  look  as  indicated 
below. 
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RHD  XYZ  HEX  H=  'K'  HLG 


nTiinmiiKHWftHBiijrnmcmm 


At  the  top  of  the  display  you  will  have  two  lines  of  information  that  describe 
the  settings  of  the  calculator.   The  first  line  shows  the  characters: 

r^ML"     I     nc..-  -.  K— 

For  details  on  the  meaning  of  these  specifications  see  Chapter  2. 
The  second  line  shows  the  characters:  ■  HuNE  :■■  indicating  that  the  HOME 
directory  is  the  current  file  directory  in  the  calculator's  memory.  In  Chapter  2 
you  will  learn  that  you  can  save  data  in  your  calculator  by  storing  them  in  files 
or  variables.  Variables  can  be  organized  into  directories  and  sub-directories. 
Eventually,  you  may  create  a  branching  tree  of  file  directories,  similar  to  those 
in  a  computer  hard  drive.  You  can  then  navigate  through  the  file  directory 
tree  to  select  any  directory  of  interest.  As  you  navigate  through  the  file 
directory  the  second  line  of  the  display  will  change  to  reflect  the  proper  file 
directory  and  sub-directory. 

At  the  bottom  of  the  display  you  will  find  a  number  of  labels,  namely, 


associated  with  the  six  soft  menu  keys,  Fl  through  F6: 

The  six  labels  displayed  in  the  lower  part  of  the  screen  will  change  depending 
on  which  menu  is  displayed.  But  r~fl~l  will  always  be  associated  with  the  first 
displayed  label,        with  the  second  displayed  label,  and  so  on. 

Menus 

The  six  labels  associated  with  the  keys  CKJ  through  CKJ  form  part  of  a  menu 
of  functions.  Since  the  calculator  has  only  six  soft  menu  keys,  it  only  display  6 
labels  at  any  point  in  time.  However,  a  menu  can  have  more  than  six  entries. 
Each  group  of  6  entries  is  called  a  Menu  page.  The  current  menu,  known  as 
the  TOOL  menu  (see  below),  has  eight  entries  arranged  in  two  pages.  The 
next  page,  containing  the  next  two  entries  of  the  menu  is  available  by 
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pressing  the  [nxtJ  (NeXT  menu)  key.  This  key  is  the  third  key  from  the  left  in 
the  third  row  of  keys  in  the  keyboard.  Press  {.nxt}  once  more  to  return  to  the 
main  TOOL  menu,  or  press  the  [Toa]  key  (third  key  in  second  row  of  keys  from 
the  top  of  the  keyboard). 

The  TOOL  menu  is  described  in  detain  in  the  next  section.  At  this  point  we 
will  illustrate  some  properties  of  menus  that  you  will  find  useful  while  using 
your  calculator. 

SOFT  menus  vs.  CHOOSE  boxes 

Menus,  or  SOFT  menus,  associate  labels  in  the  lower  part  of  the  screen  with 

the  six  soft  menu  keys  {(JL)  through  ).  By  pressing  the  appropriate  soft 
menu  key,  the  function  shown  in  the  associated  label  gets  activated.  For 
example,  with  the  TOOL  menu  active,  pressing  the  wajarna  key  (C^  )  activates 
function  CLEAR,  which  erases  (clears  up)  the  contents  of  the  screen.  To  see 
this  function  in  action,  type  a  number,  say  I  /  Jl  2  Jl  J  }[inter],  and  then  press 
the  ffT)  key. 

SOFT  menus  are  typically  used  to  select  from  among  a  number  of  related 
functions.  However,  SOFT  menus  are  not  the  only  way  to  access  collections 
of  related  functions  in  the  calculator.  The  alternative  way  will  be  referred  to 
as  CHOOSE  boxes.  To  see  an  example  of  a  choose  box,  activate  the  TOOL 
menu  (press  [rooj),  and  then  press  the  keystroke  combination 
[  }_BAS£  (associated  with  the  (.  3  J  key).  This  will  provide  the  following 
CHOOSE  box: 


SflSE  HEnu 

3.0CT  K 

H.Ein  X 

5.R-* 

1       1       1  icflncL 

OK 

This  CHOOSE  box  is  labeled  BASE  MENU  and  provides  a  list  of  numbered 
functions,  from  1 .  HEX  x  to  6.  B^R.  This  display  will  constitute  the  first  page 
of  this  CHOOSE  box  menu  showing  six  menu  functions.  You  can  navigate 
through  the  menu  by  using  the  up  and  down  arrow  keys,  /^^pr? ,  located  in 
the  upper  right  side  of  the  keyboard,  right  under  the        and  CKJ  soft  menu 
keys.  To  activate  any  given  function,  first,  highlight  the  function  name  by 
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using  the  up  and  down  arrow  keys,  (^^'^▼7 ,  or  by  pressing  the  number 
corresponding  to  the  function  in  the  CHOOSE  box.  After  the  function  name  is 
selected,  press  the  iSSSB  soft  menu  key  (r»~l ).  Thus,  if  you  wanted  to  use 
function  R^B  (Real  to  Binary),  you  could  press  CZDCKD  • 

If  you  want  to  move  to  the  top  of  the  current  menu  page  in  a  CHOOSE  box, 
use     J/a\  .  To  move  to  the  bottom  of  the  current  page,  use  CHD'^I?  •  To 
move  to  the  top  of  the  entire  menu,  use  Lr»        .  To  move  to  the  bottom  of 
the  entire  menu,  use  (.  r»  J'st?  . 

Selecting  SOFT  menus  or  CHOOSE  boxes 

You  con  select  the  format  in  which  your  menus  will  be  displayed  by  changing 
a  setting  in  the  calculator  system  flags  (A  system  flag  is  a  calculator  variable 
that  controls  a  certain  calculator  operation  or  mode.  For  more  information 
about  flags,  see  Chapter  24).  System  flag  1 1  7  can  be  set  to  produce  either 
SOFT  menus  or  CHOOSE  boxes.  To  access  this  flag  use: 


Your  calculator  will  show  the  following  screen,  highlighting  the  line  starting 
with  the  number  1  1  7: 


By  default,  the  line  will  look  as  shown  above.  The  highlighted  line  (117 
CHOOSE  boxes)  indicates  that  CHOOSE  boxes  are  the  current  menu  display 
setting.  If  you  prefer  to  use  SOFT  menu  keys,  press  the  1/1111  soft  menu  key 
(C«D ),  followed  by  iyliii  (CKJ  )■  Press  liillS  (QQ )  once  more  to  return  to 
normal  calculator  display. 

If  you  now  press  [j^_base  ^  instead  of  the  CHOOSE  box  that  you  saw  earlier, 
the  display  will  now  show  six  soft  menu  labels  as  the  first  page  of  the  STACK 
menu: 


(modeJ 
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To  navigate  through  the  functions  of  this  menu,  press  the  (wxT)  key  to  move  to 
the  next  page,  or  (3D 5^  (associated  v/ith  the  C^l)  key)  to  move  to  the 
previous  page.    The  following  figures  show  the  different  pages  of  the  BASE 


Pressing  the  [hxt)  key  once  more  will  takes  us  back  to  the  first  menu  page. 

Note:  With  the  SOFT  menu  setting  for  system  flag  117,  the  keystroke 
combination  I  J  (hold)  ^3? ,  will  show  a  list  of  the  functions  in  the  current  soft 
menu.  For  example,  for  the  two  first  pages  in  the  BASE  menu,  you  will  get: 


DEC 
DCT 
BIN 

B-^R 


To  revert  to  the  CHOOSE  boxes  setting,  use: 

 tass        ^^i^iEiiiiB  isiaai  iaasa.  

Notes: 

1.  The  TOOL  menu,  obtained  by  pressing  iroaj,  will  always  produce  a 
SOFT  menu. 

2.  Most  of  the  examples  in  this  user's  manual  are  shown  using  both  SOFT 
menus  and  CHOOSE  boxes.    Programming  applications  (Chapters  21  and 

22)  use  exclusively  SOFT  menus. 

3.  Additional  information  on  SOFT  menus  vs.  CHOOSE  boxes  is  presented 
in  Chapter  2  o  f  this  guide. 


The  TOOL  menu 

The  soft  menu  keys  for  the  menu  currently  displayed,  known  as  the  TOOL 
menu,  are  associated  with  operations  related  to  manipulation  of  variables  (see 
pages  for  more  information  on  variables): 

ilHijil     flT]      EDIT  the  contents  of  a  variable  (see  Chapter  2  and  Appendix 
L  for  more  information  on  editing) 
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Siri]]  (jT)  VIEW  the  contents  of  a  variable 

iliaill  r«~]  ReCaLl  the  contents  of  a  variable 

lEHI  CHJ  STOre  the  contents  of  a  variable 

I3II331  QD  PURGE  a  variable 

m133  (jD  clear  the  display  or  stack 


The  calculator  has  only  six  soft  menu  keys,  and  can  only  display  6  labels  at 
any  point  in  time.  Hov/ever,  a  menu  can  have  more  than  six  entries.  Each 
group  of  6  entries  is  called  a  Menu  page.  The  TOOL  menu  has  eight  entries 
arranged  in  two  pages.  The  next  page,  containing  the  next  tv/o  entries  of  the 
menu  are  available  by  pressing  the  [nxt)  (NeXT  menu)  key.  This  key  is  the 
third  key  from  the  left  in  the  third  rov^  of  keys  in  the  keyboard. 
In  this  case,  only  the  first  two  soft  menu  keys  have  commands  associated  with 
them.  These  commands  are: 

SflSaSIl    CZD      CASCMD:  CAS  CoMmanD,  used  to  launch  a  command  from 

the  CAS  by  selecting  from  a  list 
E3M    QD      HELP  facility  describing  the  commands  available 
Pressing  the  (nxt)    key  will  show  the  original  TOOL  menu.    Another  way  to 
recover  the  TOOL  menu  is  to  press  the  Ijool]  key  (third  key  from  the  left  in  the 
second  row  of  keys  from  the  top  of  the  keyboard). 

Setting  time  and  date 

The  calculator  has  an  internal  real  time  clock.  This  clock  can  be  continuously 
displayed  on  the  screen  and  be  used  for  alarms  as  well  as  running  scheduled 
tasks.  This  section  will  show  not  only  how  to  set  time  and  date,  but  also  the 
basics  of  using  CHOOSE  boxes  and  entering  data  in  a  dialog  box.  Dialog 
boxes  on  your  calculator  are  similar  to  a  computer  dialog  box. 

To  set  time  and  date  we  use  the  TIME  choose  box  available  as  an  alternative 
function  for  the  [  9  J  key.  By  combining  the  red  right-shift  button,  L  r>  J,  with 
the  L9J  key  the  TIME  choose  box  is  activated.  This  operation  can  also  be 
represented  as  [    J  time  .  The  TIME  choose  box  is  shown  in  the  figure  below: 
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2. Sit  alOfH.. 

3. Sit  tins,  iite.. 

H.Toolf.. 


As  indicated  above,  the  TIME  menu  provides  four  different  options,  numbered 
1  thirough  4.  Of  interest  to  us  as  this  point  is  option  3.  Set  time,  date...  Using 
the  dov/n  arrow  key,  highlight  this  option  and  press  the  lililillji  C«3  soft 
menu  key.  The  following  input  form  (see  Appendix  1-A)  for  adjusting  time 
and  date  is  shown: 


TiH«  : 
Dote : 


£ET  TIHE  HHD  DHTE 


EDIT  CHOO£ 


Setting  the  time  of  the  day 

Using  the  number  keys,  LiJC2DCX3CSDCZDCiJLZJCZIlC9jC5J,  start  by 
adjusting  the  hour  of  the  day.  Suppose  that  we  change  the  hour  to  11,  by 
pressing  I  /  Jl  /  J  as  the  hour  field  in  the  SET  TIME  AND  DATE  input  form  is 
highlighted.  This  results  in  the  number  7  ]  being  entered  in  the  lower  line  of 
the  input  form: 


£ET  TIHE  HHD  DHTE 


01  :34  PM 

3 '■30 '■03  M/D.^Y 


Press  the  ::°::T::°::' [jT]  soft  menu  key  to  effect  the  change.  The  value  of  77  is 
now  shown  in  the  hour  field,  and  the  minute  field  is  automatically  highlighted: 


TiH«  : 
DO't« : 


£ET  TIHE  HDD  DHTE 
11  :[SH^34  PM 

3 '■30 '■03  M/D.^Y 


Enttr  Hinutt 


EDIT  CHOD£ 


CHnCL  OK 
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Let's  change  the  minute  field  to  25,  by  pressing:  LJJLU  HlilGlll .  The 
seconds  field  is  now  highlighted.  Suppose  that  you  want  to  change  the 
seconds  field  to  45,  use:      QDCID  BESn 

The  time  format  field  is  now  highlighted.    To  change  this  field  from  its  current 
setting  you  can  either  press  the  [  *i-  J    key  (the  second  key  from  the  left  in  the 
fifth  row  of  keys  from  the  bottom  of  the  keyboard),  or  press  the  SSEES  soft 
menu  key  (  r«~] ). 

•  If  using  the  I  *i-  J    key,  the  setting  in  the  time  format  field  will  change  to 
either  of  the  following  options: 

o    AM  :  indicates  that  displayed  time  is  AM  time 
o    PM  :  indicates  that  displayed  time  is  PM  time 
o    24-hr  :  indicates  that  that  the  time  displayed  uses  a  24  hour 
format  where!  8:00,  for  example,  represents  6pm 

The  last  selected  option  will  become  the  set  option  for  the  time  format  by 
using  this  procedure. 

•  If  using  the  Iljilllj!l!y5l  soft  menu  key,  the  following  options  are  available. 


H^ET  TINE  AHD 

TiH« 

AH 

■ 

Dote 

aH-h*ur  ■tiHi 

Chms  AM,  PM,  *r  an 

-h*ur  ■tiM< 

1         1  1 

ICAnCLl 

OK 

Use  the  up  and  down  arrow  keys,,^^  to  select  among  these  three 

options  (AM,  PM,  24-hour  time).  Press  the  SEHSffn  soft  menu  key  to 
make  the  selection. 

Setting  the  date 

After  setting  the  time  format  option,  the  SET  TIME  AND  DATE  input  form  will 
look  as  follows: 


Page  1-9 


TiH« 
Dote 


£ET  TIHE  HHD  DHTE^ 
11 -25 :45  Si 


Ch^^jt  flHj  FHj  <}{■  ZH-h^ur  •tint 


To  set  the  date,  first  set  the  date  format.  The  default  format  is  M/D/Y 
(month/day/year).  To  modify  this  format,  press  the  down  arrow  key.  This 
will  highlight  the  date  format  as  shown  below: 


£ET  TIHE  HHD  DHTE 


TiH« : 
Dote : 


11  -25  :45  RM 

3  '■30  '■03 


Use  the  BIEES  soft  menu  key  (  B),  to  see  the  options  for  the  date  format: 


Tl.H« 

Day. Month. V«ar 

Highlight  your  choice  by  using  the  up  and  down  arrow  keys,i"^  ,  and 
press  the  IIEEii  r«~]  soft  menu  key  to  make  the  selection. 


Introducing  the  calculator's  keyboard 

The  figure  below  shows  a  diagram  of  the  calculator's  keyboard  with  the 
numbering  of  its  rows  and  columns. 
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Colu 

Row 

1  ► 

2  ► 

3  ► 

4  ► 

5  ► 

6  ► 
/► 

8  ► 

9  ► 
10  ► 


mn: 


1 

▼ 


3 

T 


5 
▼ 


6 

T 


CMDUNDO  PRG  CHARS  MTRW  EQW  MTH  CAT    DEL  CLEAR 


ALPHAI    I  LAJ    L?^  I    I  ^ 

CALC  ALG  MATRICES  STAT  CONVERT  UNnS  ( )  — 


ARLTH  CMPU<  DEE     LIB     #    BASE     {  )  « » 


CONT  OEE  oo 


Colu 


mn: 


ON       I  0 

CANCEL 

A  A 

2 


>  ANS-NUM 
ENTER 


A 

4 


A 

5 


The  figure  shows  1 0  rows  of  keys  combined  with  3,  5,  or  6  columns.    Row  1 
has  6  keys,  rows  2  and  3  hove  3  keys  each,  and  rows  4  through  1 0  have  5 
keys  each.  There  are  4  arrow  keys  located  on  the  right-hand  side  of  the 
keyboard  in  the  space  occupied  by  rows  2  and  3. 

Each  key  has  three,  four,  or  five  functions.  The  main  key  function  correspond 
to  the  most  prominent  label  in  the  key.   Also,  the  green  left-shift  key,  key  (8, 1), 
the  red  right-shift  key,  key  (9, 1),  and  the  blue  ALPHA  key,  key  (7, 1),  can  be 
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combined  with  some  of  the  other  keys  to  activate  the  alternative  functions 
shown  in  the  keyboard.    For  example,  the  {jyMBj  key,  key(4,4),  has  the 
following  six  functions  associated  with  it: 

isTMBj  Main  function,  to  activate  the  SYMBolic  menu 

Left-shift  function,  to  activate  the  MTH  (Math)  menu 
Right-shift  function,  to  activate  the  CATalog  function 
ALPHA  function,  to  enter  the  upper-case  letter  P 
ALPHA-Left-Shift  function,  to  enter  the  lower-case  letter  p 
ALPHA-Right-Shift  function,  to  enter  the  symbol  P 
Of  the  six  functions  associated  with  the  key  only  the  first  four  are  shown  in  the 
keyboard  itself.  This  is  the  way  that  the  key  looks  in  the  keyboard: 


[ALm)(p\ 


MTH 


CAT 


SYMB  P 


Notice  that  the  color  and  the  position  of  the  labels  in  the  key,  namely,  SYMB, 
MTH,  CA7 and  P,  indicate  which  is  the  main  function  (SYMB),  and  which  of 
the  other  three  functions  is  associated  with  the  left-shift  ^^(A^rH),  right- 
shift  C3  (CAT)  ,  and  (alpha]  (P)  keys. 

For  detailed  information  on  the  calculator  keyboard  operation  referee  to 
Appendix  B  . 

Selecting  calculator  modes 

This  section  assumes  that  you  are  now  at  least  partially  familiar  with  the  use  of 
choose  and  dialog  boxes  (if  you  are  not,  please  refer  to  Chapter  2). 

Press  the  ImodeJ  button  (second  key  from  the  left  on  the  second  row  of  keys  from 
the  top)  to  show  the  following  CALCULATOR  MODES  input  form: 
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^^^CflLCULflTOR  HOPES 

nuHb<r  F*rHOt....S'td  _FMj 
HnjU  H«o;ur4....Rodion; 
C**rd  SyftiH  Rictan^ulor 


FLflGSlCHOOSi  CflSf  DISP  ICflnCLl  OK 


Press  the  lli;[!liCZD  soft  menu  key  to  return  to  normal  display.  Examples  of 
selecting  different  calculator  modes  are  sfiown  next. 

Operating  Mode 

Tfie  calculator  offers  two  operating  modes:  tfie  Algebraic  mode,  and  tfie 
Reverse  Polish  Notation  (RPN)  mode.  The  default  mode  is  the  Algebraic 
mode  (as  indicated  in  the  figure  above),  however,  users  of  earlier  HP 
calculators  may  be  more  familiar  with  the  RPN  mode. 

To  select  an  operating  mode,  first  open  the  CALCULATOR  MODES  input  form 
by  pressing  the  Imode)  button.  The  Operating  Mode  field  will  be  highlighted. 
Select  the  Algebraic  or  RPN  operating  mode  by  either  using  the  [  *i-  J  key 
(second  from  left  in  the  fifth  row  from  the  keyboard  bottom),  or  pressing  the 
IHlE!E!I§I  soft  menu  key  (  ).  If  using  the  latter  approach,  use  up  and  down 
arrow  keys,  /aN,  to  select  the  mode,  and  press  the  liSSil  soft  menu  key 

to  complete  the  operation. 

To  illustrate  the  difference  between  these  two  operating  modes  we  will 
calculate  the  following  expression  in  both  modes: 


1  ^ 


3-3J 


23^ 


2.5 

■  e 


To  enter  this  expression  in  the  calculator  we  will  first  use  the  equation  writer, 
[r^ }  £Qw  .  Please  identify  the  following  keys  in  the  keyboard,  besides  the 
numeric  keypad  keys: 

CS  CD     Cxj     C3  CE] 
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The  equation  writer  is  a  display  mode  in  which  you  con  build  mathematical 
expressions  using  explicit  mathematical  notation  including  fractions, 
derivatives,  integrals,  roots,  etc.  To  use  the  equation  writer  for  writing  the 
expression  shown  above,  use  the  following  keystrokes: 

S  CJD  CTD  CD  CD  CTD  S3     QD  CZD  CID 

After  pressing  {inter}  the  calculator  displays  the  expression: 

V  (3*  (5-1/ (3*3)  ) /23'^3+EXP  (2.5)  ) 


Pressing  (^ra) again  will  provide  the  following  value.  Accept  Approx.  mode 
on,  if  asked,  by  pressing  SHIill.  [Note:  The  integer  values  used  above,  e.g., 
3,  5,  1,  represent  exact  values.  The  EXP(2.5),  however,  cannot  be  expressed 


as  an  exact  value,  therefore,  a  switch  to  Approx  mode  is  required] 


You  could  also  type  the  expression  directly  into  the  display  without  using  the 
equation  writer,  as  follows: 

CDCZDCiD  C5J(^CTDCZDCxDCXDCZDCDCD 
S  CS  dD  CD  C3  CE  CB  CS  ^— CID  CI3  CE 

to  obtain  the  same  result. 


Change  the  operating  mode  to  RPN  by  first  pressing  the  [Mopfj  button.  Select 
the  RPN  operating  mode  by  either  using  the  I  *i-  J  key,  or  pressing  the  ISIEEeI 


soft  menu  key.    Press  the  lliillii!  (jD    soft  menu  key  to  complete  the  operation. 


The  display,  for  the  RPN  mode  looks  as  follows: 


EDIT   VIEH    RCL  ^TO^  PURGE  CLEHR 
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Notice  that  the  display  shows  several  levels  of  output  labeled,  from  bottom  to 
top,  OS  1,  2,  3,  etc.  This  is  referred  to  as  the  stack  of  the  calculator.  The 
different  levels  are  referred  to  as  the  stack  levels,  i.e.,  stack  level  1,  stack  level 
2,  etc. 

Basically,  what  RPN  means  is  that,  instead  of  writing  an  operation  such  as  3 
+  2,  in  the  calculator  by  using  I  3  Jl  +  Jl  2  Rinter)^  we  write  first  the  operands, 
in  the  proper  order,  and  then  the  operator,  i.e.,  CJD(^ra)CZD(^^C+D  •  As 
you  enter  the  operands,  they  occupy  different  stack  levels.  Entering 
[  3  J[fW7-ffljputs  the  number  3  in  stack  level  1.  Next,  entering  [  2  J [fl^raj  pushes 
the  3  upwards  to  occupy  stack  level  2.  Finally,  by  pressing  I  +  J,  we  are 
telling  the  calculator  to  apply  the  operator,  or  program,  L+J  to  the  objects 
occupying  levels  1  and  2.  The  result,  5,  is  then  placed  in  level  1.  A  simpler 
way  to  calculate  this  operation  is  by  using:  [  3  )[£nter][  2  Jl  +  J . 

Let's  try  some  other  simple  operations  before  trying  the  more  complicated 
expression  used  earlier  for  the  algebraic  operating  mode: 


Notice  the  position  of  the  y  and  the  x  in  the  last  two  operations.  The  base  in 
the  exponential  operation  is  y  (stack  level  2)  while  the  exponent  is  x  (stack 
level  1)  before  the  key  QD  is  pressed.  Similarly,  in  the  cubic  root  operation, 
y  (stack  level  2)  is  the  quantity  under  the  root  sign,  and  x  (stack  level  1 )  is  the 
root. 

Try  the  following  exercise  involving  3  factors:  (5  +  3)  x  2 


1 23/32 
N27 


CD  SD  CX)     CID  C2D  CED 
C2DC7D(^CIDC3^ 


QDCD 


Calculates  (5  +3)  first. 
Completes  the  calculation. 


Let's  try  now  the  expression  proposed  earlier: 


2.5 
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[TDCZnt^^     Enter  3  in  level  1 

CTirniiWH]     Enter  5  in  level  1,  3  moves  to  y 

I  J  Jl  •  J(bv7h]     Enter  3  in  level  1,  5  moves  to  level  2,  3  to  level  3 

i  3  ][_  •  Jl  X  J      Place  3  and  multiply,  9  appears  in  level  1 

LaJ  1/(3x3),  last  value  in  lev.  1;  5  in  level  2;  3  in  level  3 

(.  —  J  5  ■  1/(3x3) ,  occupies  level  1  nov/;  3  in  level  2 

I  X  J  3x  (5  -  1/(3x3)),  occupies  level  1  now. 

CTDCTDCZDI^S) Enter  23  in  level  1,  14.66666  moves  to  level  2. 

CTDGJCZD     Enter  3,  calculate  23^  into  level  1 .  14.666  in  lev.  2. 

(3x  (5-l/(3x3)))/233  into  level  1 
CTDGDCID     Enter  2.5  level  1 

UxJ^   e^'^,  goes  into  level  1,  level  2  shov/s  previous  value. 

C+J  (3x  (5  -  1  /(3x3)))/232 ,  e^  5  =  12.1 8369,  into  lev.  1 . 

V((3x  (5  -  l/(3x3)))/23^e2  5)  =  3.4905156,  into  1. 


Although  RPN  requires  a  little  bit  more  thought  than  the  algebraic  (ALG)  mode, 
there  are  multiple  advantages  in  using  RPN.  For  example,  in  RPN  mode  you 
con  see  the  equation  unfolding  step  by  step.  This  is  extremely  useful  to  detect 
a  possible  input  error.  Also,  as  you  become  more  efficient  in  this  mode  and 
learn  more  of  the  tricks,  you  will  be  able  to  calculate  expression  faster  and 
will  much  less  keystrokes.  Consider,  for  example  the  calculation  of  (4x6  - 
5)/(l  +4x6  -  5).  In  RPN  mode  you  can  write: 

obviously,  even  In  RPN  mode,  you  can  enter  an  expression  in  the  same  order 

OS  the  algebraic  mode  by  using  the  Equation  writer.  For  example, 

C3  _£2^      CID  CZD  CX3  CZD  Q  CTD     CID  GD  CED  C3D  CZD 

^^^^^^^ 
(3  CID  OD  CD  CZD  dD  CD  CD      (S3     QD  CZD  CID 


The  resulting  expression  is  shown  in  stack  level  1  as  follows: 


aft 


er  pressing 


Notice  how  the  expression  is  placed  in  stack  leve 
Pressing  the  EVAL  key  at  this  point  will  evaluate  the  numerical  value  of  that 
expression  Note:  In  RPN  mode,  pressing  ENTER  when  there  is  no  command 
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line  will  execute  the  DUP  function  which  copies  the  contents  of  stock  level  1  of 
the  stock  onto  level  2  (and  pushes  all  the  other  stack  levels  one  level  up).  This 
is  extremely  useful  as  showed  in  the  previous  example. 

To  select  between  the  ALG  vs.  RPN  operating  mode,  you  can  also  set/clear 
system  flog  95  through  the  following  keystroke  sequence: 

SSjIS^QD^:^(5D(^C5D  ^  iv^BSmSI  B33S  EI3S 
Alternatively,  you  can  use  one  of  the  following  shortcuts: 

•  In  ALG  mode, 

CF(-95)  selects  RPN  mode 

•  In  RPN  mode, 

95  L  *i-  jlENTER)  SF  selects  ALG  mode 

For  more  information  on  calculator's  system  flags  see  Chapter  2. 
Number  Format  and  decimal  dot  or  comma 

Changing  the  number  format  allows  you  to  customize  the  way  real  numbers 
are  displayed  by  the  calculator.  You  will  find  this  feature  extremely  useful  in 
operations  with  powers  of  tens  or  to  limit  the  number  of  decimals  in  a  result. 

To  select  a  number  format,  first  open  the  CALCULATOR  MODES  input  form  by 
pressing  the  LmomJ  button.  Then,  use  the  down  arrow  key,  to  select  the 
option  Number  format.  The  default  value  is  Std,  or  Standard  format.  In  the 
standard  format,  the  calculator  will  show  floating-point  numbers  with  the 
maximum  precision  allowed  by  the  calculator  (12  significant  digits).  To  learn 
more  about  reals,  see  Chapter  2.  To  illustrate  this  and  other  number  formats 
try  the  following  exercises: 

•    Standard  format: 

This  mode  is  the  most  used  mode  as  it  shows  numbers  in  the  most  familiar 
notation. 

Press  the  iEISBI  soft  menu  key,  with  the  Number  format  set  to  Std,  to 
return  to  the  calculator  display.  Enter  the  number  1  23.45678901  23456. 
Notice  that  this  number  has  1 6  significant  figures.  Press  the  [entek)  key. 
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The  number  is  rounded  to  the  maximum  1 2  significant  figures,  and  is 
displayed  as  follows: 


123.4567S9012 

123.4567S90ia 


EDIT   VIEH    RCL  ^TO^  PURGE  CLEHR 


In  the  standard  format  of  decimal  display,  integer  numbers  are  shown 
with  no  decimal  zeros  whatsoever.  Numbers  with  different  decimal 
figures  will  be  adjusted  in  the  display  so  that  only  those  decimal  figures 
that  are  necessary  will  be  shown.  More  examples  of  numbers  in  standard 
format  are  shown  next: 


:  125. 

125. 

:25.69S 

25.698 

: 56.254379 

56.254379 

EDITIVIEHI  RCL 

1  ^^^!^  IPURGEICLEHR 

Fixed  format  with  no  decimals:    Press  the  [modeJ  button.    Next,  use  the 

down  arrow  key,       ,  to  select  the  option  Number  format.    Press  the 
ifliEii§  soft  menu  key  (  (JL)  )f  and  select  the  option  Fixed  with  the  arrow 
down  key  . 


CHLCULHTOR  HODES 

nuHb«r  ForHat....l*Bl  0 
HnjU  H«o;ur4....Rodion; 

C**rd  SyftiH  Rictan^ulor 

^R<«P    _K<y  ClicR    ^Loft  StocR 

Ch**f<  nuHb«r  difpUy  f^rHot 


Notice  that  the  Number  Format  mode  is  set  to  Fix  followed  by  a  zero  (0). 
This  number  indicates  the  number  of  decimals  to  be  shown  after  the 
decimal  point  in  the  calculator's  display.  Press  the  iiSSII  soft  menu  key 
to  return  to  the  calculator  display.   The  number  now  is  shown  as: 


123. 


123, 


EDIT   VIEH    RCL  ^TD^  PURGE  CLEHR 


This  setting  will  force  all  results  to  be  rounded  to  the  closest  integer  (0 
digit  displayed  after  the  comma).  However,  the  number  is  still  stored  by 
the  calculator  with  its  full  1  2  significant  digit  precision.  As  we  change  the 
number  of  decimals  to  be  displayed,  you  will  see  the  additional  digits 
being  shown  again. 
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Fixed  format  with  decimals: 

This  mode  is  mainly  used  when  working  with  limited  precision.  For 
example,  if  you  are  doing  financial  calculation,  using  a  FIX  2  mode  is 
convenient  as  it  con  easily  represent  monetary  units  to  a  1/100  precision. 
Press  the  [modeJ  button.  Next,  use  the  down  arrow  key,  ,  to  select  the 
option  Number  format.  Press  the  Y."!':!'!!:  soft  menu  key  ( (jQ  );  and  select 
the  option  Fixed  with  the  arrow  down  key  ' 


CHLCULHTOR  HODE£ 

nuHb«r  ForHat....l*Bl  0 
HnjU  H«o;ur4....Rodion; 

C**rd  SyftiH  Rictan^ulor 

^R<«P    _K<y  ClicR    ^Loft  StocR 

Ch**f<  nuHb«r  difpUy  f^rHot 


FLAGS  CHOOS   CflS    DISP  CflnCL  OK 


Press  the  right  arrow  key,  CD,  to  highlight  the  zero  in  front  of  the  option 
Fix.    Press  the  !!'::":'!::!"::'  soft  menu  key  and,  using  the  up  and  down  arrow 
keys,  ,  select,  soy,  3  decimals.  


nuHb 
Anal 


.FM, 

tocR 
■  lay 


Press  the  iSiisisoft  menu  key  to  complete  the  selection: 


CALCULATOR  NODES 
Op«ro'tins  H«d«..AI.3«braic 
nuAb<r  F*rHO't....Fix    9  _FMj 
Ansl.«  H4o;ur«....Ro4ionf 

C**rd  SyftiH  R«ctan3Ular 

^R«<p     _Ki])  Click    ^LoJt  StocR 


FLAGS  CHOOS   CAS    DISP  CAACL  OK 


Press  the  HKllllsoft  menu  key  return  to  the  calculator  display, 
number  now  is  shown  as: 


Th€ 


123.457 


123.457 


EDIT   VIEH    RCL    STO^  PURGE  CLEAR 


Notice  how  the  number  is  rounded,  not  truncated.  Thus,  the  number 

1  23.45678901  23456,  for  this  setting,  is  displayed  as  1  23.457,  and  not 

as  1  23.456  because  the  digit  after  6  is  >  5 
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•    Scientific  format 

The  scientific  format  is  mainly  used  when  solving  problems  in  the  physical 
sciences  where  numbers  are  usually  represented  as  a  number  with  limited 

precision  multiplied  by  a  power  of  ten. 

To  set  this  format,  start  by  pressing  the  [mode)  button.  Next,  use  the  down 
arrow  key,  ,  to  select  the  option  Number  format  Press  the  EiliEEle]  soft 
menu  key  (  C2D  ),  and  select  the  option  Scientific  with  the  arrow  down  key 
•sX? .  Keep  the  number  3  in  front  of  the  Sci.  (This  number  can  be 
changed  in  the  same  fashion  that  we  changed  the  Fixed  number  of 
decimals  in  the  example  above). 

^^^CflLCULflTOR  MODES 

nuHb<r  ForHat....MH    3  _FMj 
Hn^U  H«o;ur4....Rodion; 
C**rd  SyftiH  Rictan^ulor 


FLflGSlCHOOS[  CflSf  DISP  ICflnCLl  OK 


Press  the  lilCllll  soft  menu  key  return  to  the  calculator  display.  The 
number  now  is  shown  as: 

:  1.235E2 

1 . 235E2 


EDIT|VIEH|  RCL  |  STO^  |PURGE|CLEHR 


This  result,  1 .23E2,  is  the  calculator's  version  of  powers-of-ten  notation, 
i.e.,  1.235  X  10^.  In  this,  so-called,  scientific  notation,  the  number  3  in 
front  of  the  Sci  number  format  (shown  earlier)  represents  the  number  of 
significant  figures  after  the  decimal  point.  Scientific  notation  always 
includes  one  integer  figure  as  shown  above.  For  this  case,  therefore,  the 
number  of  significant  figures  is  four. 

•     Engineering  format 

The  engineering  format  is  very  similar  to  the  scientific  format,  except  that 
the  powers  of  ten  are  multiples  of  three. 

To  set  this  format,  start  by  pressing  the  [mode)  button.  Next,  use  the  down 
arrow  key,  ,  to  select  the  option  Number  format.  Press  the  '  soft 
menu  key  (  (JL)  ),  and  select  the  option  Engineering  with  the  arrow  down 
key  "sj? .  Keep  the  number  3  in  front  of  the  Eng.  (This  number  can  be 
changed  in  the  same  fashion  that  we  changed  the  Fixed  number  of 
decimals  in  an  earlier  example). 
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CflLCULflTOR  MODES  ^^^^ 

nuHb<r  F*rH0t....En3    9  _FMj 
Hn^U  H«o;ur4....Rodion; 
C**rd  SyftiH  Rictan^ulor 

Ch««f«  dcciHol.  pyiiis  t<}  difpUy 


FLAGS  CHOOS   CflS    DISP  CflnCL  OK 


Press  the  IEI3lsoft  menu  key  return  to  the  calculator  display, 
number  now  is  shown  as: 


The 


123. 5E 


EDIT   VIEH    RCL    STD^  PURGE  CLEAR 


Because  this  number  has  three  figures  in  the  integer  part,  it  is  shown  with 
four  significative  figures  and  a  zero  power  of  ten,  while  using  the 
Engineering  format.  For  example,  the  number  0.00256,  will  be  shown  as: 


123. 5E0 
2.560E-3 


123. 5E0 
2.560E-3 


EDIT   VIEH    RCL    STD^  PURGE  CLEAR 


Decimal  comma  vs.  decimal  point 

Decimal  points  in  floating-point  numbers  can  be  replaced  by  commas,  if 
the  user  is  more  familiar  with  such  notation.  To  replace  decimal  points  for 
commas,  change  the  FM  option  in  the  CALCULATOR  MODES  input  form 
to  commas,  as  follows  (Notice  that  we  have  changed  the  Number  Format 

to  Std): 

Press  the  [mode]  button.  Next,  use  the  down  arrow  key,       ,  once,  and  the 

right  arrow  key,  CD,  highlighting  the  option  FM,.    To  select  commas, 

M  soft  menu  key  (i.e.,  the  r«~]  key).  The  input  form  will 


press  the  ll^l  

look  as  follows 


CALCULATOR  NODES 
Optrotins  H«d«..AI.s<broic 
nuAb<r  F*rA0t....S'td 
AnsU  H«o;ur4....Rodion; 

C**rd  SyftiH  Rictan^ulor 

^D<«P    _K<y  ClicR    ^Loft  StocR 

Jf<  t*AAO  It  Frocti^n  AorR? 


FLAGS^CHK   CAS    DISP  CAnCL  OK 


Press  the  lEijlisoft  menu  key  return  to  the  calculator  display. 


The 


number  123.456789012,  entered  earlier,  now  is  shown  as: 


123,456739012 

123,456739012 


EDIT   VIEH    RCL    STO^  PURGE  CLEAR 
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Angle  Measure 

Trigonometric  functions,  for  example,  require  arguments  representing  plane 
angles.  The  calculator  provides  tfiree  different  Angle  Measure  modes  for 
working  witfi  angles,  namely: 

•  Degrees:  Tfiere  are  360  degrees  (360°)  in  a  complete  circumference,  or 
90  degrees  (90°)  in  a  rigfit  angle.  Tfiis  representation  is  mainly  used 
wfien  doing  basic  geometry,  mecfianical  or  structural  engineering,  and 
surveying. 

•  Radians:  Tfiere  are  2;r  radians  (2;^')  in  a  complete  circumference,  or  ;r/2 
radians  (v'2  ^  in  a  right  angle.  This  notation  is  mainly  used  when  solving 
mathematics  and  physics  problems.  This  is  the  default  mode  of  the 
calculator. 

•  Grades:  There  are  400  grades  (400  s)  in  a  complete  circumference,  or 
700  grades  (?  00  ®)  in  a  right  angle.  This  notation  is  similar  to  the  degree 
mode,  and  was  introduced  in  order  to  "simplify"  the  degree  notation  but 
is  seldom  used  now. 

The  angle  measure  affects  the  trig  functions  like  SIN,  COS,  TAN  and 
associated  functions. 

To  change  the  angle  measure  mode,  use  the  following  procedure: 

•  Press  the  [i^oe)  button.  Next,  use  the  down  arrow  key,  twice.  Select 
the  Angle  Measure  mode  by  either  using  the  I  *i-  J  key  (second  from  left  in 
the  fifth  row  from  the  keyboard  bottom),  or  pressing  the  03]llj!l§l  soft  menu 
key  (  CEJ ).  If  using  the  latter  approach,  use  up  and  down  arrow 
keys,<^>  "sV?,  to  select  the  preferred  mode,  and  press  the  w^SCK)  soft 
menu  key  to  complete  the  operation.  For  example,  in  the  following 
screen,  the  Radians  mode  is  selected: 

^^^CflLCULflTOR  MODES 

nuHb<r  F^rHJt....S'tj  _FM, 
Hn^U  H«o;ur4....[XEBES 
C**rd  SyftiH  Rictan^ulor 


FLflGSlCHOOSi  CflSf  DISP  ICflnCLl  OK 


Coordinate  System 
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The  coordinate  system  selection  affects  the  way  vectors  and  complex  numbers 
are  displayed  and  entered.  To  learn  more  about  complex  numbers  and 
vectors,  see  Chapters  4  and  9,  respectively. 

Two-  and  three-dimensional  vector  components  and  complex  numbers  can  be 
represented  in  any  of  3  coordinate  systems:  The  Cartesian  (2  dimensional)  or 
Rectangular  (3  dimensional),  Cylindrical  (3  dimensional)  or  Polar  (2 
dimensional),  and  Spherical  (only  3  dimensional).  In  a  Cartesian  or 
Rectangular  coordinate  system  a  point  P  will  have  three  linear  coordinates 
(x,y,z)  measured  from  the  origin  along  each  of  three  mutually  perpendicular 
axes  (in  2  d  mode,  z  is  assumed  to  be  0).  In  a  Cylindrical  or  Polar 
coordinate  system  the  coordinates  of  a  point  are  given  by  (r,0,z),  where  r  is  a 
radial  distance  measured  from  the  origin  on  the  xy  plane,  6  is  the  angle  that 
the  radial  distance  r  forms  with  the  positive  x  axis  ~  measured  as  positive  in  a 
counterclockwise  direction  -,  and  z  is  the  same  as  the  z  coordinate  in  a 
Cartesian  system  (in  2  d  mode,  z  is  assumed  to  be  0).  The  Rectangular  and 
Polar  systems  are  related  by  the  following  quantities: 


x  =  r-  cos(^) 
y  =  r-  sin(^) 


0  =  tan 


,    2   ,  2 

IX  +y 
yxj 


z  =  z 


In  a  Spherical  coordinate  system  the  coordinates  of  a  point  are  given  by 
(p,0,(|))  where  p  is  a  radial  distance  measured  from  the  origin  of  a  Cartesian 
system,  6  is  an  angle  representing  the  angle  formed  by  the  projection  of  the 
linear  distance  p  onto  the  xy  axis  (same  as  0  in  Polar  coordinates),  and  ^  is 
the  angle  from  the  positive  z  axis  to  the  radial  distance  p.  The  Rectangular 
and  Spherical  coordinate  systems  are  related  by  the  following  quantities: 

p  =  -^x^  +z^ 


x  =  p-  sin(^)  •  cos(^) 
y  =  p- sm{^)  ■  sin(d)         0  =  tan 

z  =  p-  cos(^)  ^  =  tan" 


yxj 


yjx 


To  change  the  coordinate  system  in  your  calculator,  follow  these  steps: 
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•  Press  the  (mode)  button.  Next,  use  the  down  arrow  key,  three  times. 
Select  the  Angle  Measure  mode  by  either  using  the  (j^^J  key  (second  from 
left  in  the  fifth  row  from  the  keyboard  bottom),  or  pressing  the  SSEEm  soft 
menu  key  (  ).  If  using  the  latter  approach,  use  up  and  down  arrow 
keys,(^^  "^3?,  to  select  the  preferred  mode,  and  press  the  liLiEliil  soft 
menu  key  to  complete  the  operation.  For  example,  in  the  following 
screen,  the  Polar  coordinate  mode  is  selected: 

^^^CflLCULflTOR  MODES 

nuHb<r  F*rHOt....S'td  _FMj 
flnaU  Htjjur<....Rjjijnj 
C44rd  Syft^H  [SEI^^^H 


FLflGSlCHOOSi  CflSf  DISP  ICflnCLl  OK 


Beep,  Key  Click,  and  Last  Stack 

The  last  line  of  the  CALCULATOR  MODES  input  form  include  the  options: 

Beep  _Key  Click  _Last  Stack 
By  choosing  the  check  mark  next  to  each  of  these  options,  the  corresponding 
option  is  activated.  These  options  are  described  next: 

_Beep   :  When  selected,  ,  the  calculator  beeper  is  active.  This  operation 

mainly  applies  to  error  messages,  but  also  some  user  functions  like 
BEEP. 

_Key  Click  :  When  selected,  each  keystroke  produces  a  "click"  sound. 
_Last  Stack:  Keeps  the  contents  of  the  last  stack  entry  for  use  with  the  functions 
UNDO  and  ANS  (see  Chapter  2). 

The  _Beep  option  can  be  useful  to  advise  the  user  about  errors.  You  may 
want  to  deselect  this  option  if  using  your  calculator  in  a  classroom  or  library. 
The  _Key  Click  option  can  be  useful  as  an  audible  way  to  check  that  each 
keystroke  was  entered  as  intended. 

The  _Last  Stack  option  is  very  useful  to  recover  the  last  operation  in  case  we 
need  it  for  a  new  calculation. 

To  select,  or  deselect,  any  of  these  three  options,  first  press  the  LmqdcJ  button. 
Next, 
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•  Use  the  down  arrow  key,      four  times  to  select  the    Last  Stack  option. 
Use  the  ll^jiilil  soft  menu  key  (i.e.,  the  (JL)  key)  to  change  the  selection. 

•  Press  the  left  arrow  key  CT)   to  select  the  _/Cey  C/;c/c  option.  Use  the  j'/aUSS 
soft  menu  key  (i.e.,  the  (JL)  key)  to  change  the  selection. 

•  Press  the  left  arrow  key  (3D  to  select  the  _Beep  option.  Use  the  ii^^lllll  soft 
menu  key  (i.e.,  the  C2Q  key)  to  change  the  selection. 

Press  the  SSEII8iC«D  soft  menu  key  to  complete  the  operation. 


CAS  stands  for  Computer  Algebraic  System.  This  is  the  mathematical  core  of 
the  calculator  where  the  symbolic  mathematical  operations  and  functions  are 
programmed  and  performed.  The  CAS  offers  a  number  of  settings  can  be 
adjusted  according  to  the  type  of  operation  of  interest.  These  are: 

•  The  default  independent  variable 

•  Numeric  vs.  symbolic  mode 

•  Approximate  vs.  Exact  mode 

•  Verbose  vs.  Non-verbose  mode 

•  Step-by-step  mode  for  operations 

•  Increasing  power  format  for  polynomials 

•  Rigorous  mode 

•  Simplification  of  non-rational  expressions 

Details  on  the  selection  of  CAS  settings  are  presented  in  Appendix  C. 

Selecting  Display  modes 

The  calculator  display  can  be  customized  to  your  preference  by  selecting 
different  display  modes.  To  see  the  optional  display  settings  use  the  following: 

•  First,  press  the  [mode]  button  to  activate  the  CALCULATOR  MODES  input 
form.  Within  the  CALCULATOR  MODES  input  form,  press  the  SHi^SSS  soft 
menu  key  (CZD  )  to  display  the  DISPLAY  MODES  input  form. 


Selecting  CAS  settings 


iFcnt:  Ft  S_0:  SYSTEM  S 

lEdit:  B^HOU  _FuU  Fi^s  _Ind<nt 
|E4H:    _ShoU  _SmoU  Stick  Dilf 
tin  ujinj  jhjU  f^nt?  

iklMilliiESISIIBI^ 
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•  To  navigate  through  the  many  options  in  the  DISPLAY  MODES  input  form, 
use  the  arrow  keys:  C3DCD^^c^  • 

•  To  select  or  deselect  any  of  the  settings  shown  above,  that  require  a  check 
mark,  select  the  underline  before  the  option  of  interest,  and  toggle  the 
|,/:ii;|Tl soft  menu  key  until  the  right  setting  is  achieved.  When  an  option  is 
selected,  a  check  mark  will  be  shown  in  the  underline  (e.g.,  the  Texfbook 
option  in  the  Stack:  line  above).  Unselected  options  will  show  no  check 
mark  in  the  underline  preceding  the  option  of  interest  (e.g.,  the  _Small, 
_Full  page,  and  Jndeni  options  in  the  Edii:  line  above). 

•  To  select  the  Font  for  the  display,  highlight  the  field  in  front  of  the  font: 
option  in  the  DISPLAY  MODES  input  form,  and  use  the  SalliEBl  soft  menu 
key  (CZD  ). 

•  After  having  selected  and  unselected  all  the  options  that  you  want  in  the 
DISPLAY  MODES  input  form,  press  the  SumS  soft  menu  key.  This  will  take 
you  back  to  the  CALCULATOR  MODES  input  form.  To  return  to  normal 
calculator  display  at  this  point,  press  the  luSlI  soft  menu  key  once  more. 


Selecting  the  display  font 

Changing  the  font  display  allows  you  to  have  the  calculator  look  and  feel 
changed  to  your  own  liking.  By  using  a  6-pixel  font,  for  example,  you  can 
display  up  to  9  stack  levels!  Follow  these  instructions  to  select  your  display 
font: 

First,  press  the  \j«xx]  button  to  activate  the  CALCULATOR  MODES  input  form. 
Within  the  CALCULATOR  MODES  input  form,  press  the  TiT::'::':  soft  menu  key 
(QQ)  to  display  the  DISPLAY  MODES  input  form.  The  Font:  field  is 
highlighted,  and  the  option  Ft8_0:system  8  is  selected.  This  is  the  default 
value  of  the  display  font.    Pressing  the  HIEEB  soft  menu  key  ((JL) ),  will 


provide  a  list  of  availab 


e  system  fonts,  as  shown  below: 


DI^PLHY  HODES 


Font  e 

F*nt 
Edit 

Ch**f<  faf't<M  Font 


The  options  available  are  three  standard  System  Fonts  (sizes  8,  7,  and  6)  and 
a  Browse.,  option.    The  latter  will  let  you  browse  the  calculator  memory  for 


Page  1-26 


additional  fonts  that  you  may  have  created  (see  Chapter  23)  or  downloaded 
into  the  calculator. 

Practice  changing  the  display  fonts  to  sizes  7  and  6.  Press  the  OK  soft  menu 
key  to  effect  the  selection.  When  done  with  a  font  selection,  press  the  lillllS 
soft  menu  key  to  go  back  to  the  CALCULATOR  MODES  input  form.  To  return 
to  normal  calculator  display  at  this  point,  press  the  lulSlli  soft  menu  key  once 
more  and  see  how  the  stack  display  change  to  accommodate  the  different  font. 

Selecting  properties  of  the  line  editor 

First,  press  the  (mode)  button  to  activate  the  CALCULATOR  MODES  input  form. 
Within  the  CALCULATOR  MODES  input  form,  press  the  lEil^aisoft  menu  key 
(CfL) }  to  display  the  DISPLAY  MODES  input  form.  Press  the  down  arrow  key, 
once,  to  get  to  the  Edit  line.  This  line  shows  three  properties  that  con  be 
modified.  When  these  properties  are  selected  (checked)  the  following  effects 
are  activated: 

Small  Changes  font  size  to  small 

_Full  page        Allows  to  place  the  cursor  after  the  end  of  the  line 
Jndent  Auto  intend  cursor  when  entering  a  carriage  return 

Detailed  instructions  on  the  use  of  the  line  editor  are  presented  in  Chapter  2  in 
this  guide. 

Selecting  properties  of  the  Stock 

First,  press  the  (mox)  button  to  activate  the  CALCULATOR  MODES  input  form. 
Within  the  CALCULATOR  MODES  input  form,  press  the  ijiilEiEiLiiii  soft  menu  key 
(CfD  )  to  display  the  DISPLAY  MODES  input  form.  Press  the  down  arrow  key, 
twice,  to  get  to  the  Stack  line.  This  line  shows  two  properties  that  con  be 
modified.  When  these  properties  are  selected  (checked)  the  following  effects 
are  activated: 

_Small  Changes  font  size  to  small.    This  maximized  the  amount  of 

information  displayed  on  the  screen.  Note,  this  selection 
overrides  the  font  selection  for  the  stack  display. 

_Textbook  Display  mathematical  expressions  in  graphical  mathematical 
notation 
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To  illustrate  these  settings,  either  in  algebraic  or  RPN  mode,  use  the  equation 
writer  to  type  the  following  definite  integral: 

(^_£gw[W)  (CZDCE)I3D°^CDQD^C^(3CD(21(^ 

In  Algebraic  mode,  the  following  screen  shows  the  result  of  these  keystrokes 
with  neither  _Small  nor   Textbook  are  selected: 

:  J^<0,«,EXP<-X>,X> 


+^KIP|SKIP^  H)EL  I  DEL-f|DEL  L|  inS  ■ 


With  the  _Small  option  selected  only,  the  display  looks  as  shown  below: 


+*EL  I  DEL-f|DEL  L|  inS  ■ 


With  the  _Textbook  option  selected  (default  value),  regardless  of  whether  the 
_Sma// option  is  selected  or  not,  the  display  shows  the  following  result: 


1 


+^KIP|SKIP^  H)EL  I  DEL-f|DEL  L|  inS  ■ 


Selecting  properties  of  the  equation  writer  (EQW) 

First,  press  the  [MoofJ  button  to  activate  the  CALCULATOR  MODES  input  form. 
Within  the  CALCULATOR  MODES  input  form,  press  the  =:n"::T::":  soft  menu  key 
(QD  )  to  display  the  DISPLAY  MODES  input  form.  Press  the  down  arrow  key, 
three  times,  to  get  to  the  EQW  (Equation  Writer)  line.  This  line  shows 
two  properties  that  can  be  modified.  When  these  properties  are  selected 
(checked)  the  following  effects  are  activated: 

_Small  Changes  font  size  to  small  while  using  the  equation 

editor 

_Small  Stack  Disp         Shows  small  font  in  the  stack  for  textbook  style 

display 

Detailed  instructions  on  the  use  of  the  equation  editor  (EQW)  are  presented 
elsewhere  in  this  manual. 
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For  the  example  of  the  integral      e    dX ,  presented  above,  selecting  the 

_Sma//  Stoc/c  D/sp  in  the  5QW  line  of  the  DISPLAY  MODES  input  form 
produces  the  following  display: 

V'' 

J  0 

1 


+^KIP|SKIP^  H)EL  I  DEL-f|DEL  L|  inS  ■ 


Selecting  the  size  of  the  header 

First,  press  the  button  to  activate  the  CALCULATOR  MODES  input  form. 
Within  the  CALCULATOR  MODES  input  form,  press  the  lii^yjs  soft  menu  key 
(C2D  )  to  display  the  DISPLAY  MODES  input  form.  Press  the  dov/n  arrow  key, 
four  times,  to  get  to  the  Header  line.  The  value  2  is  assigned  to  the 
Header  field  by  default.  This  means  that  the  top  part  of  the  display  will 
contain  two  lines,  one  showing  the  current  settings  of  the  calculator,  and  a 
second  one  showing  the  current  sub  directory  within  the  calculator's  memory 
(These  lines  were  described  earlier  in  the  manual).  The  user  can  select  to 
change  this  setting  to  /  or  0  to  reduce  the  number  of  header  lines  in  the 
display. 

Selecting  the  clock  display 

First,  press  the  (mox}  button  to  activate  the  CALCULATOR  MODES  input  form. 
Within  the  CALCULATOR  MODES  input  form,  press  the  kiiii™  soft  menu  key 
((jD  )  to  display  the  DISPLAY  MODES  input  form.  Press  the  down  arrow  key, 
,  four  times,  to  get  to  the  Header  line.  The  Header  field  will  be 
highlighted.  Use  the  right  arrow  key  (C5D)  to  select  the  underline  in  front  of 
the  options  _Clock  or  _Analog.  Toggle  the  ||>/jinTjil|  soft  menu  key  until  the 
desired  setting  is  achieved.  If  the  _Clock  option  is  selected,  the  time  of  the 
day  and  date  will  be  shown  in  the  upper  right  corner  of  the  display.  If  the 
_Analog  option  is  also  selected,  an  analog  clock,  rather  than  a  digital  clock, 
will  be  shown  in  the  upper  right  corner  of  the  display.  If  the  _Clock  option  is 
not  selected,  or  the  header  is  not  present,  or  too  small,  the  date  and  time  of 
day  will  not  be  shown  in  the  display. 
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Chapter  2 

Introducing  the  calculator 

In  this  chapter  we  present  a  number  of  basic  operations  of  the  calculator 
including  the  use  of  the  Equation  Writer  and  the  manipulation  of  data  objects 
in  the  calculator.  Study  the  examples  in  this  chapter  to  get  a  good  grasp  of 
the  capabilities  of  the  calculator  for  future  applications. 

Calculator  objects 

Any  number,  expression,  character,  variable,  etc.,  that  con  be  created  and 
manipulated  in  the  calculator  is  referred  to  as  an  object.  Some  of  the  most 
useful  type  of  objects  are  listed  below. 

Real.  These  object  represents  a  number,  positive  or  negative,  with  1 2 
significant  digits  and  an  exponent  ranging  from  -499  to  +499.  example  of 
reals  are:  1 -5.,  56.41 564  1 .5E45,  -555.74E-95 

When  entering  a  real  number,  you  can  use  the  [nx  J  key  to  enter  the  exponent 
and  the  I  +i-  J  key  to  change  the  sign  of  the  exponent  or  mantissa. 

Note  that  real  must  be  entered  with  a  decimal  point,  even  if  the  number  does 
not  have  a  fractional  part.  Otherwise  the  number  is  token  as  an  integer 
number,  which  is  a  different  calculator  objects.  Reals  behave  as  you  would 
expect  a  number  to  when  used  in  a  mathematical  operation. 

Integers.  These  objects  represent  integer  numbers  (numbers  without  fractional 
part)  and  do  not  have  limits  (except  the  memory  of  the  calculator).  Example 
of  integers  are:  1,  564654112,  -413165467354646765465487.  Note 
how  these  numbers  do  not  have  a  decimal  point. 

Due  to  their  storage  format,  integer  numbers  are  always  maintain  full 
precision  in  their  calculation.  For  example,  an  operation  such  as  30/14,  with 
integer  numbers,  will  return  15/7  and  not  2.142....  To  force  a  real  (or 
floating-point)  result,  use  function  ^NUM  I  r»  J "f^,  . 

Integers  are  used  frequently  in  CAS-based  functions  as  they  are  designed  to 
keep  full  precision  in  their  operation.. 
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If  the  approximate  mode  (APPROX)  is  selected  in  the  CAS  (see  Appendix  C), 
integers  will  be  automatically  converted  to  reals,  if  you  are  not  planning  to  use 
the  CAS,  it  might  be  a  good  idea  to  switch  directly  into  approximate  mode. 
Refer  to  Appendix  C  for  more  details. 

Mixing  integers  and  reals  together  or  mistaking  an  integer  for  a  real  is  a 
common  occurrence.  The  calculator  will  detect  such  mixing  of  objects  and  ask 
you  if  you  want  to  switch  to  approximate  mode. 

Complex  numbers,  are  an  extension  of  real  numbers  that  include  the  unit 
imaginary  number,  /  ^=  -1 .  A  complex  number,  e.g.,  3  +  2i,  is  written  as  (3, 
2)  in  the  calculator. 

Complex  numbers  can  be  displayed  in  either  Cartesian  or  polar  mode 
depending  on  the  setting  selected.  Note  that  complex  numbers  are  always 
stored  in  Cartesian  mode  and  that  only  the  display  is  affected.  This  allows  the 
calculator  to  keep  as  much  precision  as  possible  during  calculations. 

Most  mathematics  functions  work  on  complex  numbers.  There  is  no  need  to 
use  a  special  "complex  +"  function  to  add  complex  numbers,  you  can  use  the 
same  I  +  J  function  that  on  reals  or  integers. 

Vector  and  matrix  operations  utilize  objects  of  type  3,  real  arrays,  and,  if 
needed,  type  4,  complex  arrays.  Objects  type  2,  strings,  are  simply  lines  of 
text  (enclosed  between  quotes)  produced  with  the  alphanumeric  keyboard. 

A  list  is  just  a  collection  of  objects  enclosed  between  curly  brackets  and 
separated  by  spaces  in  RPN  mode  (the  space  key  is  labeled  I spc})^  or  by 
commas  in  algebraic  mode.  Lists,  objects  of  type  5,  can  be  very  useful  when 
processing  collections  of  numbers.  For  example,  the  columns  of  a  table  can  be 
entered  as  lists.  If  preferred,  a  table  can  be  entered  as  a  matrix  or  array. 

Objects  type  8  are  programs  in  User  RPL  language.  These  are  simply  sets  of 
instructions  enclosed  between  the  symbols  «  ». 

Associated  with  programs  are  objects  types  6  and  7,  Global  and  Local 

Names,  respectively.  These  names,  or  variables,  are  used  to  store  any  type 
of  objects.  The  concept  of  global  or  local  names  is  related  to  the  scope  or 
reach  of  the  variable  in  a  given  program. 
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An  algebraic  object,  or  simply,  an  algebraic  (object  of  type  9),  is  a  valid 

algebraic  expression  enclosed  between  apostrophes. 

Binary  integers,  objects  of  type  10,  are  used  in  some  computer  science 
applications. 

Graphics  objects,  objects  of  type  1 1 ,  store  graphics  produced  by  the 
calculator. 

Tagged  objects,  objects  of  type  1  2,  are  used  in  the  output  of  many  programs 
to  identify  results.  For  example,  in  the  tagged  object:  Mean:  23.2,  the  word 
Mean:  is  the  tag  used  to  identify  the  number  23.2  as  the  mean  of  a  sample,  for 


Unit  objects,  objects  of  type  1 3,  are  numerical  values  with  a  physical  unit 
attached  to  them. 

Directories,  objects  of  type  1 5,  are  memory  locations  used  to  organize  your 
variables  in  a  similar  fashion  as  folders  are  used  in  a  personal  computer. 

Libraries,  objects  of  type  16,  are  programs  residing  in  memory  ports  that  are 
accessible  within  any  directory  (or  sub-directory)  in  your  calculator.  They 
resemble  built-in  functions,  objects  of  type  1  8,  and  built-in  commands,  objects 
of  type  1 9,  in  the  way  they  are  used. 

Editing  expressions  in  the  screen 

In  this  section  we  present  examples  of  expression  editing  directly  into  the 
calculator  display  (algebraic  history  or  RPN  stack). 

Creating  arithmetic  expressions 

For  this  example,  we  select  the  Algebraic  operating  mode  and  select  a  Fix 
format  with  3  decimals  for  the  display.   We  are  going  to  enter  the  arithmetic 
expression: 


example. 


1.0  + 


1.0 


5.0- 


7.5 


To  enter  this  expression  use  the  following  keystrokes: 
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CED  CZJ  CT3  a  CB  CTD  CI3  S  CZ3  CD  CTJ  CD  S 

CS)1^  (SdDGDQCZDCIDCQCiD 

The  resulting  expression  is:  5.*(1  .+1  ./7.5)/(--r3.-2.''3). 
Press  [inter]  to  get  the  expression  in  the  display  as  follows: 


-.904070293597 


+^KIP|SKIP^  H)EL  I  DEL-f|DEL  L|  inS  ■ 


Notice  that,  if  your  CAS  is  set  to  EXACT  (see  Appendix  C)  and  you  enter  your 
expression  using  integer  numbers  for  integer  values,  the  result  is  a  symbolic 
quantity,  e.g., 

CSD  CxD     1^  CD     CD  S  CZD     CC  CD  S 
ED  1^      CX)  Q  CTD 

Before  producing  a  result,  you  will  be  asked  to  change  to  Approximate  mode. 
Accept  the  change  to  get  the  following  result  (shown  in  Fix  decimal  mode  with 
three  decimal  places  -  see  Chapter  1 ): 


5.  000. 

fl  000+1-0001 

■is.  000-2.  000^'^^^ 

■H  H)EL  1  DEL-f|DEL  L| 

ins  ■ 

In  this  case,  when  the  expression  is  entered  directly  into  the  stack,  as  soon  as 
you  press  [cnter)  ,  the  calculator  will  attempt  to  calculate  a  value  for  the 
expression.  If  the  expression  is  entered  between  quotes,  however,  the 
calculator  will  reproduce  the  expression  as  entered.    In  the  following  example, 
we  enter  the  same  expression  as  above,  but  using  quotes.  For  this  case  we 
set  the  operating  mode  to  Algebraic,  the  CAS  mode  to  Exact  (deselect 
Approx),  and  the  display  setting  to  Textbook.  The  keystrokes  to  enter  the 
expression  are  the  following: 

CDCDCDC^l^  CD  CD  CD  CD  CD  CD  CS  CDS 

S  CX3  (DJ  QJ  CD 
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The  result  will  be  shown  as  follows: 


To  evaluate  the  expression  we  can  use  the  EVAL  function,  as  follows: 

Ieval]!  <n  ]ANS 


As  in  the  previous  example,  you  will  be  asked  to  approve  changing  the  CAS 
setting  to  Approx.   Once  this  is  done,  you  will  get  the  same  result  as  before. 

An  alternative  way  to  evaluate  the  expression  entered  earlier  between  quotes 
is  by  using  the  option  I    J  ^i^^m  .    Jo  recover  the  expression  from  the  existing 
stack,  use  the  following  keystrokes:  (.    Jl  4  J[  ]*num 

We  will  now  enter  the  expression  used  above  when  the  calculator  is  set  to  the 
RPN  operating  mode.  We  also  set  the  CAS  to  Exact  and  the  display  to 
Textbook.  The  keystrokes  to  enter  the  expression  between  quotes  are  the 
same  used  earlier,  i.e., 

CZDCX3  (X]  CB  QD     CZH     CTD  CD  S 

Resulting  in  the  output 


l: 

EDIT|VIEH|  RCL 

1  ^^^!^  IPURGEICLEHR 

Press  [wrfflj  once  more  to  keep  two  copies  of  the  expression  available  in  the 
stack  for  evaluation.  We  first  evaluate  the  expression  using  the  function  EVAL, 
and  next  using  the  function  -^NUM.  First,  evaluate  the  expression  using 
function  EVAL.  The  resulting  expression  is  semi-symbolic  in  the  sense  that 
there  are  floating-point  components  to  the  result,  as  well  as  a  V3.    Next,  we 
switch  stack  locations  and  evaluate  using  function  ^NUM: 


CD 

[  |->  J  -NUM 


Exchange  stack  levels  1  and  2  (the  SWAP  command) 
Evaluate  using  function  ^NUM 
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This  latter  result  is  purely  numerical,  so  that  the  two  results  in  the  stack, 
although  representing  the  same  expression,  seem  different.  To  verify  that  they 
are  not,  we  subtract  the  two  values  and  evaluate  this  difference  using  function 

EVAL: 

I  —  J  Subtract  level  1  from  level  2 

l£VAL)  Evaluate  using  function  EVAL 

The  result  is  zero  (0.). 

Note:  Avoid  mixing  integer  and  real  data  to  avoid  conflicts  in  the 

calculations.  For  many  physical  science  and  engineering  applications, 
including  numerical  solution  of  equation,  statistics  applications,  etc.,  the 
APPROX  mode  (see  Appendix  C)  works  better.  For  mathematical 
applications,  e.g.,  calculus,  vector  analysis,  algebra,  etc.,  the  EXACT  mode  is 
preferred.  Become  acquainted  with  operations  in  both  modes  and  learn  how 
to  switch  from  one  to  the  other  for  different  types  of  operations  (see  Appendix 

Q.  

Editing  arithmetic  expressions 

Suppose  that  we  entered  the  following  expression,  between  quotes,  with  the 
calculator  in  RPN  mode  and  the  CAS  set  to  EXACT: 


l: 

5. 

I.75J 

EDIT   VIEH  RCL 

PURGE  CLEHR 

1  + 

1 

expression:  5 

.Th 

-2' 

was  entered  by  using: 

CD  CX]  [X3  (X)     (X3  S  QD  Q  [X]  CX3  CD  S  SI)  ^i- 

CX3CXCXC2DCQCX(^ 

To  enter  the  line  editor  use  [  ^  J^<^  .  The  display  now  looks  as  follows: 
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45*<  1-1/1. 75>^<-J"5-2-^3 


+^KIP|SKIP^  H)EL  I  DEL-f|DEL  L|  inS  ■ 


The  editing  cursor  is  shown  as  a  blinking  left  arrow  over  the  first  character  in 
the  line  to  be  edited.   Since  the  editing  in  this  case  consists  of  removing  some 
characters  and  replacing  them  with  others,  we  will  use  the  right  and  left  arrow 
keys,  C3D(T5,  to  move  the  cursor  to  the  appropriate  place  for  editing,  and  the 
delete  key,  (.  4  J,  to  eliminate  characters. 

The  following  keystrokes  will  complete  the  editing  for  this  case: 

•  Press  the  right  arrow  key,  CD,  until  the  cursor  is  immediately  to  the 
right  of  the  decimal  point  in  the  term  J. 75 

•  Press  the  delete  key,  C5D,  twice  to  erase  the  characters  ?. 

•  Press  the  right  arrow  key,  CD ,  once,  to  move  the  cursor  to  the  right  of 
the  7 

•  Type  a  decimal  point  with  [  •  J 

•  Press  the  right  arrow  key,  CD ,  until  the  cursor  is  immediately  to  the 
right  of  the  V5 

•  Press  the  delete  key,  I  4  J  ,  once  to  erase  the  character  5 

•  Type  a  3  with  [  3  J 

•  Press  [INTER}  to  return  to  the  stack 

The  edited  expression  is  now  available  in  the  stack. 

7.5} 


EDITlVIEHl  RCL  |  £T0^  IPURGEICLEHR 


Editing  of  a  line  of  input  when  the  calculator  is  in  Algebraic  operating  mode  is 
exactly  the  same  as  in  the  RPN  mode.  You  can  repeat  this  example  in 
Algebraic  mode  to  verify  this  assertion. 

Creating  algebraic  expressions 

Algebraic  expressions  include  not  only  numbers,  but  also  variable  names.  As 
an  example,  we  will  enter  the  following  algebraic  expression: 
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R  +  y 


We  set  the  calculator  operating  mode  to  Algebraic,  the  CAS  to  Exact,  and  the 
display  to  Textbook.  To  enter  this  algebraic  expression  we  use  the  following 
keystrokes: 

CZD  CX]  CxD  (^™]  (S  CXD  S      1^  CX]  CTD 
Press  [INTER}  to  get  the  following  result: 


Entering  this  expression  when  the  calculator  is  set  in  the  RPN  mode  is  exactly 
the  same  as  this  Algebraic  mode  exercise. 

Editing  algebraic  expressions 

Editing  of  an  algebraic  expression  with  the  line  editor  is  very  similar  to  that  of 
an  arithmetic  expression  (see  exercise  above).  Suppose  that  we  want  to 
modify  the  expression  entered  above  to  read 


To  edit  this  algebraic  expression  using  the  line  editor  use  (.  <n  .  This 
activates  the  line  editor,  showing  the  expression  to  be  edited  as  follows: 


2*L*T  <  1  +x.^R  V  t  R+y  >  +2* 
L/b 
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The  editing  cursor  is  shown  as  a  blinking  left  arrow  over  the  first  character  in 
the  line  to  be  edited.   As  in  an  earlier  exercise  on  line  editing,  we  will  use  the 
right  and  left  arrow  keys,  (3DCD ,  to  move  the  cursor  to  the  appropriate 
place  for  editing,  and  the  delete  key,  (3D,  to  eliminate  characters. 

The  following  keystrokes  will  complete  the  editing  for  this  case: 

•  Press  the  right  arrow  key,  CD ,  until  the  cursor  is  to  the  right  of  the  x 

•  Type  QlDCXD  to  enter  the  power  2  for  the  x 

•  Press  the  right  arrow  key,  CE) ,  until  the  cursor  is  to  the  right  of  the  y 

•  Press  the  delete  key,  I  4  J,  once  to  erase  the  characters  y. 

•  Type  [Mfiji} UxJ (3  to  enter  an  x 

•  Press  the  right  arrow  key,  CD  r  4  times  to  move  the  cursor  to  the  right 
of  the  * 

•  Type  I  ^  J  to  enter  a  square  root  symbol 

•  Type  C5H(i       to  enter  a  set  of  parentheses  (they  come  in  pairs) 

•  Press  the  right  arrow  key,  CD,  once,  and  the  delete  key,  I    J,  once, 
to  delete  the  right  parenthesis  of  the  set  inserted  above 

•  Press  the  right  arrow  key,  CD ,  4  times  to  move  the  cursor  to  the  right 
of  the  b 

•  Type      }<2       to  enter  a  second  set  of  parentheses 

•  Press  the  delete  key,  I  4  J,  once,  to  delete  the  left  parenthesis  of  the 
set  inserted  above. 

•  Press  [euter]  to  return  to  normal  calculator  display. 

The  result  is  shown  next: 


■  R- 

^  R  .2-L 
^y  b 

2.x>Jbr-IRI+2^ 

2  2 
R  +X 

 SOtb^RMR+x) 

EDIT  1  <l 

IEH|  RCL  1  £T0^  IPURGEICLEHR 

Notice  that  the  expression  has  been  expanded  to  include  terms  such  as 
I  R I ,  the  absolute  value,  and  SQ(b  R),  the  square  of  b-R.  To  see  if  we  can 
simplify  this  result,  use  FACTOR(ANS(l ))  in  ALG  mode: 
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:FflCTOR(flHS(l)) 


■r+x'S)'Iri+JIr  +x  'rJ 


2  Z 
(R+x>b  .R 


EDIT   VIEH    RCL  ^TO^  PURGE  CLEHR 


•     Press  [  ^  J^T?  to  activate  the  line  editor  once  more.  The  result  is  now: 


4*<  (■J"b*R+x*-J"b>*flES<R> 
Hi  <R-^£+x-^£*R>*L>*RES 
ih-}  >*RBS<R>*t-J"L*RBStb 
>>/-((R+x>*(b-^2*R-^2>> 


+^KIP  SKIP-H  H)EL   DEL-f  DEL  L  IDS  i 


•     Pressing  [mm]  once  more  to  return  to  normal  display. 

To  see  the  entire  expression  in  the  screen,  we  can  change  the  option 
_Sma//  S\ack  Disp  in  the  DISPLAY  MODES  input  form  (see  Chapter  1). 
After  effecting  this  change,  the  display  will  look  as  follows: 


((a.R+a.xJ.JFT.iRi+a.jR^+x^.R.L.ibi).ibi 


S4(b.R).(R+x) 
:FflCTDR(flnS(l)) 

[z-Jb.R*Z.^-JF)-jL.|b|.R^*Z-jR^*^^.R.|, 


b^.R^^.b^.R^ 


EDIT   VIEH    RCL  ^TD^  PURGE  CLEHR 


Note:  To  use  Greek  letters  and  other  characters  in  algebraic  expressions  use 
the  CHARS  menu.  This  menu  is  activated  by  the  keystroke 
combination  C^om  .  Details  are  presented  in  Appendix  D. 


Using  the  Equation  Writer  (EQW)  to  create  expressions 

The  equation  writer  is  an  extremely  powerful  tool  that  not  only  let  you  enter  or 
see  an  equation,  but  also  allows  you  to  modify  and  work/apply  functions  on 
oil  or  part  of  the  equation.  The  equation  writer  (EQW),  therefore,  allows  you 
to  perform  complex  mathematical  operations,  directly,  or  in  a  step-by-step 
mode,  as  you  would  do  on  paper  when  solving,  for  example,  calculus 
problems. 
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The  Equation  Writer  is  launched  by  pressing  the  keystroke  combination  [jfj 
(.  r»  J  EQw  (the  third  key  in  the  fourth  row  from  the  top  in  the  keyboard).  The 
resulting  screen  is  the  following: 


EDIT  I  CUR£  I  EIG  ■!  EVHL  |FHCTO|  £IHP 


The  six  soft  menu  keys  for  the  Equation  Writer  activate  the  following  functions: 

yil!uijliil:  lets  the  user  edit  an  entry  in  the  line  editor  (see  examples  above) 

SllSa:  highlights  expression  and  adds  a  graphics  cursor  to  it 

IIIS:  if  selected  (selection  shown  by  the  character  in  the  label)  the  font  used  in 

the  writer  is  the  system  font  8  (the  largest  font  available) 

|j3il!a:  lets  you  evaluate,  symbolically  or  numerically,  an  expression  highlighted 

in  the  equation  writer  screen  (similar  to  [  r» 

II1u1]I!lI:  lets  you  factor  an  expression  highlighted  in  the  equation  writer  screen 
(if  factoring  is  possible) 

MSS:  lets  you  simplify  an  expression  highlighted  in  the  equation  writer  screen 
(as  much  as  it  can  be  simplified  according  to  the  algebraic  rules  of  the  CAS) 

If  you  press  the  C^D  key,  two  more  soft  menu  options  show  up  as  shown 
below: 


The  six  soft  menu  keys  for  the  Equation  Writer  activate  the  following  functions: 

ifljJiiSi:  allows  access  to  the  collection  of  CAS  commands  listed  in  alphabetical 
order.  This  is  useful  to  insert  CAS  commands  in  an  expression  available  in  the 

Equation  Writer. 

yililll!s:  activates  the  calculator's  CAS  help  facility  to  provide  information  and 
examples  of  CAS  commands. 

Some  examples  for  the  use  of  the  Equation  Writer  are  shown  below. 
Creating  arithmetic  expressions 

Entering  arithmetic  expressions  in  the  Equation  Writer  is  very  similar  to 
entering  an  arithmetic  expression  in  the  stack  enclosed  in  quotes.  The  main 
difference  is  that  in  the  Equation  Writer  the  expressions  produced  are  written 
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in  "textbook"  style  instead  of  a  line-entry  style.  Thus,  when  a  division  sign 
(i.e.,  (.  H-  J)  is  entered  in  the  Equation  Writer,  a  fraction  is  generated  and  the 
cursor  placed  in  the  numerator.  To  move  to  the  denominator  you  must  use  the 
down  arrow  key.  For  example,  try  the  following  keystrokes  in  the  Equation 
Writer  screen:  CX3Ci]CX3CTDCTD 
The  result  is  the  expression 

I  ~5~ 
5+24 


EDIT  I  CUR£  I  EIG  ■!  EVHL  |FHCTO|  £IHP 


The  cursor  is  shown  as  a  left-facing  key.  The  cursor  indicates  the  current 
edition  location.  Typing  a  character,  function  name,  or  operation  will  enter 
the  corresponding  character  or  characters  in  the  cursor  location.  For  example, 
for  the  cursor  in  the  location  indicated  above,  type  now: 

The  edited  expression  looks  as  follows: 


EDIT  I  CUR£  I  EIG  ■!  EVHL  |FHCTO|  £IHP 


Suppose  that  you  want  to  replace  the  quantity  between  parentheses  in  the 

denominator  (i.e.,  5-1-1  /3)  with  (5+n^/2).  First,  we  use  the  delete  key  (L*J) 
delete  the  current  1/3  expression,  and  then  we  replace  that  fraction  with 
as  follows:  C3DI3D(3DC5D^  CZDCID 


When  we  hit  this  point  the  screen  looks  as  follows 


EDIT  I  CUR£  I  EIG  ■!  EVHL  |FHCTD|  £IHP 


In  order  to  insert  the  denominator  2  in  the  expression,  we  need  to  highlight 
the  entire  Ji^  expression.  We  do  this  by  pressing  the  right  arrow  key  (CD ) 
once.  At  that  point,  we  enter  the  following  keystrokes:  [  ^  Jl  2  J 
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The  expression  now  looks  as  follows: 


Suppose  that  now  you  want  to  add  the  fraction  1/3  to  this  entire  expression, 
i.e.,  you  want  to  enter  the  expression: 


-  + 


1 


5  +  2  •  (5  +  — ) 
2 

First,  we  need  to  highlight  the  entire  first  term  by  using  either  the  right  arrow 
(CD)  or  the  upper  arrow       )  keys,  repeatedly,  until  the  entire  expression  is 
highlighted,  i.e.,  seven  times,  producing: 


EDIT  1  CURS  1  EIG  ■!  EVflL  |FflCTO|  SIMP 

NOTE:  Alternatively,  from  the  original  position  of  the  cursor  (to  the  right  of  the 
2  in  the  denominator  of  t^/T),  we  can  use  the  keystroke  combination  Lr»  J/a\ 
,  interpreted  as  (I    J  z  ). 


Once  the  expression  is  highlighted  as  shown  above,  type  I  +  Jl  /  Jl  Jl  3  J  to 
add  the  fraction  1/3.  Resulting  in:  


f  2] 

.      2  , 

EDIT   CURS   EIG  ■  EVflL  FflCTD  SIMP 


Showing  the  expression  in  smaller-size 

To  show  the  expression  in  a  smaller-size  font  (which  could  be  useful  if  the 
expression  is  long  and  convoluted),  simply  press  the  BIur«~]  soft  menu  key. 
For  this  case,  the  screen  looks  as  follows: 
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EDITlCUR^I  EIG  |  EVHL  |FHCTO|  £IHP 


To  recover  the  larger-font  display,  press  the  yiaijlin  r^"!  soft  menu  key  once  more. 
Evaluating  the  expression 

To  evaluate  the  expression  (or  parts  of  the  expression)  v/ithin  the  Equation 
Writer,  highlight  the  part  that  you  v^ant  to  evaluate  and  press  the  oSilJlC^D 
soft  menu  key. 


For  example,  to  evaluate  the  entire  expression  in  this  exercise,  first,  highlight 
the  entire  expression,  by  pressing  [    J  X  .  Then,  press  the  [allil!!  f"^  soft 
menu  key.    If  your  calculator  is  set  to  Exact  CAS  mode  (i.e.,  the  _Approx 
CAS  mode  is  not  checked),  then  you  will  get  the  following  symbolic  result: 


If  you  want  to  recover  the  unevaluated  expression  at  this  time,  use  the  function 
UNDO,  i.e.,  (7^ mo  (the  first  key  in  the  third  row  of  keys  from  the  top  of  the 
keyboard).  The  recovered  expression  is  shown  highlighted  as  before: 


If  you  want  a  floating-point  (numerical)  evaluation,  use  the  -^NUM  function 
(i.e.,  The  result  is  as  follows: 


.534331967616 


EDIT   CUR£   EIG  ■  EVHL  FHCTO  £IHP 
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Use  the  function  UNDO  ( [  r»  J  )  once  more  to  recover  the  original 
expression: 


EDIT  I  CUR£  I  EIG  ■!  EVHL  |FHCTO|  £IHP 


Evaluating  a  sub-expression 

Suppose  that  you  want  to  evaluate  only  the  expression  in  parentheses  in  the 
denominator  of  the  first  fraction  in  the  expression  above.  You  have  to  use  the 
arrow  keys  to  select  that  particular  sub-expression.  Here  is  a  way  to  do  it: 
Highlights  only  the  first  fraction 
Highlights  the  numerator  of  the  first  fraction 
Highlights  denominator  of  the  first  fraction 
Highlights  first  term  in  denominator  of  first  fraction 
Highlights  second  term  in  denominator  of  first  fraction 
Highlights  first  factor  in  second  term  in  denominator  of  first  fraction 
Highlights  expression  in  parentheses  in  denominator  of  first  fraction 


CD 
CD 
CD 


Since  this  is  the  sub-expression  we  want  evaluated,  we  can  now  press  the 
iSSS  CmJ  soft  menu  key,  resulting  in: 


A  symbolic  evaluation  once  more.  Suppose  that,  at  this  point,  we  want  to 
evaluate  the  left-hand  side  fraction  only.  Press  the  upper  arrow  key  (/aN,  ) 
three  times  to  select  that  fraction,  resulting  in: 
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EDIT   CURS   EIG  ■  EVflL  FflCTO  SIMP 


Then,  press  the  BUSS ffT)  soft  menu  key  to  obtain: 


EDIT  1  CURS 

1  EIG     EVflL  IFflCTDI  SIMP 

Let's  try  a  numerical  evaluation  of  this  term  at  this  point.  Use  (.  r»  J  -^"f  to 
obtain: 


EDIT   CURS   EIC  ■  EVflL  FflCTD  SIMP 


Let's  highlight  the  fraction  to  the  right,  and  obtain  a  numerical  evaluation  of 
that  term  too,  and  show  the  sum  of  these  tv/o  decimal  values  in  small-font 
format  by  using :CE)  UU ,  we  get: 


To  highlight  and  evaluate  the  expression  in  the  Equation  Writer  we  use: 
ffT] ,  resulting  in: 


EDIT   CURS    tie    EVflL  FflCTD  SIMP 


Editing  arithmetic  expressions 

We  will  show  some  of  the  editing  features  in  the  Equation  Writer  as  an 
exercise.  We  start  by  entering  the  following  expression  used  in  the  previous 
exercises: 


f  2] 

5+— 

.      2  , 

EDIT  I  CURS  I  EIC  ■!  EVflL  |FflCTD|  SIMP 
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And  will  use  the  editing  features  of  tfie  Equation  Editor  to  transform  it  into  the 
following  expression: 


5 

r  51 

TT 

Ls  J 

EDIT  1  CURS  1  EIG     EVflL  |FflCTO|  SIMP 

In  the  previous  exercises  we  used  the  arrow  keys  to  highlight  sub-expressions 
for  evaluation.  In  this  case,  we  will  use  them  to  trigger  a  special  editing  cursor. 
After  you  have  finished  entering  the  original  expression,  the  typing  cursor  (a 
left-pointing  arrow)  will  be  located  to  the  right  of  the  3  in  the  denominator  of 
the  second  fraction  as  shown  here: 


Press  the  down  arrow  key  (*si? )  to  trigger  the  clear  editing  cursor.  The  screen 
now  looks  like  this: 


5         .  1 

5+2- 

f  21 

EDIT  1  CURS  1  HIQ  -\  EVHL 

IFflCTDI  SIMP 

By  using  the  left  arrow  key  (C3D)  you  can  move  the  cursor  in  the  general  left 
direction,  but  stopping  at  each  individual  component  of  the  expression.  For 
example,  suppose  that  we  will  first  will  transform  the  expression         into  the 
expression  LN(7:P/3) .  With  the  clear  cursor  active,  as  shown  above,  press 
the  left-arrow  key  ((3D )  twice  to  highlight  the  2  in  the  denominator  of 
Next,  press  the  delete  key  (L    J)  once  to  change  the  cursor  into  the  insertion 
cursor.  Press  [    J  once  more  to  delete  the  2,  and  then  L  3  J  to  enter  a  3.  At 
this  point,  the  screen  looks  as  follows: 


5         .  1 

f  21 

"3 

EDIT  1  CURS  1  EIG  EVHL 

IFflCTDI  SIMP 
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Next,  press  the  down  arrow  key  (^^)  to  trigger  the  clear  editing  cursor 
highlighting  the  3  in  the  denominator  of  Press  the  left  arrow  key  (C3D) 

once  to  highlight  the  exponent  2  in  the  expression  Next,  press  the 

delete  key  (I  4  J)  once  to  change  the  cursor  into  the  insertion  cursor.  Press 
L_«J  once  more  to  delete  the  2,  and  then  L5j  to  enter  a  5.  Press  the  upper 
arrow  key       )  three  times  to  highlight  the  expression  Then,  type 

I  V*  J  to  apply  the  /.N  function  to  this  expression.  The  screen  now  looks 

like  this: 


EDIT  I  CUR£  I  EIG  ■!  EVHL  |FHCTO|  £IHP 


Next,  we'll  change  the  5  within  the  parentheses  to  a  y^  by  using  these 

keystrokes:  C33C53(3DQDCiDCID 

Next,  we  highlight  the  entire  expression  in  parentheses  an  insert  the  square 
root  symbol  by  using:     /^N, /aN, /j^s, /an, 

Next,  we'll  convert  the  2  in  front  of  the  parentheses  in  the  denominator  into  a 

2/3  by  using:  CT)CS3DCT]C±DC3D 
At  this  point  the  expression  looks  as  follows: 


5  A 

r  51 

L  3  J 

y  3 

EDIT  1  CUR^  1 

EIG  ■!  EVflL  IFflCTDI  SIMP 

The  final  step  is  to  remove  the  1/3  in  the  right-hand  side  of  the  expression. 
This  is  accomplished  by  using:  ^^^^^:^^^c:^Q:)ClJC3DCijC£)ClD 
The  final  version  will  be: 


EDIT  I  CURS  I  EIG  ■!  EVHL  |FHCTD|  SIHP 


In  summary,  to  edit  an  expression  in  the  Equation  Writer  you  should  use  the 
arrow  keys  ((37) CT) ^or? )  to  highlight  expression  to  which  functions  will  be 
applied  (e.g.,  the  IH  and  square  root  cases  in  the  expression  above).  Use  the 
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down  arrow  key  (^^)  in  any  location,  repeatedly,  to  trigger  the  clear  editing 
cursor.  In  this  mode,  use  the  left  or  right  arrow  keys  (CiDCE?)  to  move  from 
term  to  term  in  an  expression.  When  you  reach  a  point  that  you  need  to  edit, 
use  the  delete  key  (l  4  j)  to  trigger  the  insertion  cursor  and  proceed  with  the 
edition  of  the  expression. 


Creating  algebraic  expressions 

An  algebraic  expression  is  very  similar  to  an  arithmetic  expression,  except 
that  English  and  Greek  letters  may  be  included.  The  process  of  creating  an 
algebraic  expression,  therefore,  follows  the  same  idea  as  that  of  creating  an 
arithmetic  expression,  except  that  use  of  the  alphabetic  keyboard  is  included. 


To  illustrate  the  use  of  the  Equation  Writer  to  enter  an  algebraic  equation  we 
will  use  the  following  example.  Suppose  that  we  want  to  enter  the  expression: 


V3  I  e 


1/3 


Use  the  following  keystrokes: 

CDCD  CxD  CS_^  (^0(3  C+D  QD  CXD  (^(ZJ®  CHD  (^CED© 
This  results  in  the  output: 


i...e-.LN 


..34 


EDIT   CUR£   EIG  ■  EVHL  FHCTO  £IHP 


In  this  example  we  used  several  lower-case  English  letters,  e.g.,  x 
{(ALmA}[jj]J(x\),  several  Greek  letters,  e.g.,  A  ((41^ QlD (3 )/  and  even  a 
combination  of  Greek  and  English  letters,  namely.  Ay  ((^i^JLrU© 
(d™JL?lJ(3  )■    Keep  in  mind  that  to  enter  a  lower-case  English  letter,  you  need 
to  use  the  combination:  (^™)LjnJ  followed  by  the  letter  you  want  to  enter. 
Also,  you  can  always  copy  special  characters  by  using  the  CHARS  menu 
([  i->  J  CHARS )  if  you  don't  want  to  memorize  the  keystroke  combination  that 
produces  it.    A  listing  of  commonly  used  [Aumjl  r»  J  keystroke  combinations 
was  listed  in  an  earlier  section. 
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The  expression  tree 

The  expression  tree  is  a  diagram  showing  how  the  Equation  Writer  interprets 
an  expression.    See  Appendix  E  for  a  detailed  example. 

The  CURS  function 

The  CURS  function  (hUSh)  in  the  Equation  Writer  menu  (the  CfD  key)  converts 
the  display  into  a  graphical  display  and  produces  a  graphical  cursor  that  can 
be  controlled  with  the  arrow  keys  (CT)  CT)      '^t?  )  for  selecting  sub- 
expressions. The  sub-expression  selected  with        will  be  shown  framed  in 
the  graphics  display.  After  selecting  a  sub-expression  you  can  press  [inter]  to 
show  the  selected  sub-expression  highlighted  in  the  Equation  writer.  The 
following  figures  show  different  sub-expressions  selected  with  and  the 
corresponding  Equation  Writer  screen  after  pressing  [gga].  


CCy-3>x-H5).(x^-H4) 

CCy-3>x-H5).[x^-H4] 

ISIHC4.X-2]! 

(l(:y-3>x^5l.[x^-H4) 
SIHC4.X-2) 

C3e!EaE+5)'(x^-H4) 

SIHC4.X-2) 

EDIT   CURS   EIG  ■  EVflL  FflCTO  SIMP 

CCy-3>x-H5).(B-4) 
SIHC4.X-2) 

CCy-3).x-H5).(S-H4) 
SIHC4.X-2) 

Editing  algebraic  expressions 

The  editing  of  algebraic  equations  follows  the  same  rules  as  the  editing  of 
algebraic  equations.  Namely: 

•  Use  the  arrow  keys  (C<) CD )  to  highlight  expressions 

•  Use  the  down  arrow  key  C^^),  repeatedly,  to  trigger  the  clear  editing 
cursor  .  in  this  mode,  use  the  left  or  right  arrow  keys  (CJ)CD )  to 
move  from  term  to  term  in  an  expression. 
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•     At  an  editing  point,  use  the  delete  key  OD)  to  trigger  the  insertion 
cursor  and  proceed  with  the  edition  of  the  expression. 
To  see  the  clear  editing  cursor  in  action,  let's  start  with  the  algebraic 
expression  that  we  entered  in  the  exercise  above: 


i...e-.LN 


EDIT   CURS   EIG  ■  EVflL  FflCTO  SIMP 


Press  the  down  arrow  key,  "^7,  at  its  current  location  to  trigger  the  clear 
editing  cursor.   The  3  in  the  exponent  of  ^?will  be  highlighted.  Use  the  left 
arrow  key,  CX),  to  move  from  element  to  element  in  the  expression.  The  order 
of  selection  of  the  clear  editing  cursor  in  this  example  is  the  following  (press 
the  left  arrow  key,  C3D ,  repeatedly): 

1 .  The  1  in  the  1/3  exponent 

2.  0 

3.  Ay 

4.  n 

5.  2 

6.  x 

7.  n  in  the  exponential  function 

8.  X 

9.  3  in  the  V3  term 

1 0.  the  2  in  the  2/V3  fraction 

At  any  point  we  can  change  the  clear  editing  cursor  into  the  insertion  cursor 
by  pressing  the  delete  key  (L4J).  Let's  use  these  two  cursors  (the  clear  editing 
cursor  and  the  insertion  cursor)  to  change  the  current  expression  into  the 
following: 


SIN 


EDIT   CURS   EIC  ■  EVHL  FHCTD  SIHR 


If  you  followed  the  exercise  immediately  above,  you  should  have  the  clear 
editing  cursor  on  the  number  2  in  the  first  factor  in  the  expression.  Follow 
these  keystrokes  to  edit  the  expression: 
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l^^JLiiJLJJ  Enters  the  factorial  for  the  3  in  the  square  root 

(entering  the  factorial  changes  the  cursor  to  the  selection  cursor) 
"^^^^^^CDCD  Selects  the  //  in  the  exponential  function 

I  ^  J[  3  Jl  X  )lALPHA]l  r>  }(F]    Modifies  exponential  function  argument 
CD  CD  CD  CD  Selects  Ay 

(.  ^  J  Places  a  square  root  symbol  on  Ay 

(this  operation  also  changes  the  cursor  to  the  selection  cursor) 
^^CD^^^^  C»D  Select  0^/2  and  enter  the  SIN  function 
The  resulting  screen  is  the  following: 


Evaluating  a  sub-expression 

Since  we  already  hove  the  sub-expression  SIn{0^'^^  highlighted,  let's  press 
the  EiSiljECfD  soft  menu  key  to  evaluate  this  sub-expression.  The  result  is: 


sit^(3F)W 

EDIT  1  CURS  1  EIG     EVflL  |FflCTO|  SIMP 

Some  algebraic  expressions  cannot  be  simplified  anymore.  Try  the  following 
keystrokes:  (^(JL)  •  You  will  notice  that  nothing  happens,  other  than  the 
highlighting  of  the  entire  argument  of  the  LN  function.  This  is  because  this 
expression  cannot  be  evaluated  (or  simplified)  any  more  according  to  the 
CAS  rules.  Trying  the  keystrokes:  (^^(JL)  again  does  not  produce  any 
changes  on  the  expression.  Another  sequence  of  i^^ffQ  keystrokes, 
however,  modifies  the  expression  as  follows: 


One  more  application  of  the  /A^fTH  keystrokes  produces  more  changes: 
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3.LH 

isiHC3F)J 

\'- 

EDIT  1 

CURS  1  EIG     EVflL  |FflCTO|  SIMP 

This  expression  does  not  fit  in  the  Equation  Writer  screen.  We  con  see  the 
entire  expression  by  using  a  smaller-size  font.  Press  the  lEEiBfin  soft  menu 
key  to  get: 


EDIT  I  CURS  I  EIG  | EVHL  |FHCTO|  SIHP 


Even  with  the  larger-size  font,  it  is  possible  to  navigate  through  the  entire 
expression  by  using  the  clear  editing  cursor.  Try  the  following  keystroke 
sequence:  r«~)  ,  to  set  the  clear  editing  cursor  atop  the  factor 

3  in  the  first  term  of  the  numerator.  Then,  press  the  right  arrow  key,  CB> ,  to 
navigate  through  the  expression. 


Simplifying  an  expression 

Press  the  BI3C«D  soft  menu  key  to  get  the  screen  to  look  as  in  the  previous 
figure  (see  above).  Now,  press  the  BES.  (jQ  soft  menu  key,  to  see  if  it  is 
possible  to  simplify  this  expression  as  it  is  shown  in  the  Equation  Writer.  The 
result  is  the  following  screen: 


EDIT   CURS    EIG    EVflL  FflCTD  SIMP 


This  screen  shows  the  argument  of  the  SIN  function,  namely,  \fO  , 

LN(0) 

transformed  into  e   ^    .  This  may  not  seem  like  a  simplification,  but  it  is  in 
the  sense  that  the  cubic  root  function  has  been  replaced  by  the  inverse 
functions  exp-LN. 
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Factoring  an  expression 

In  this  exercise  we  will  try  factoring  a  polynomial  expression.  To  continue  the 
previous  exercise,  press  the  lfw?«J  key.  Then,  launch  the  Equation  Writer  again 
by  pressing  the  CrfJ_cQw  key.  Type  the  equation: 

resulting  in 

I       2  2    2  2 


EDIT  I  CUR£  I  EIG  ■!  EVHL  |FHCTO|  £IHP 


Let's  select  the  first  3  terms  in  the  expression  and  attempt  a  factoring  of  this 
sub-expression:  [  r»  J(^g^<^Lr^CDLi^J(T)  ■  This  produces: 


EDIT  I  CUR£  I  EIG  ■!  EVHL  |FHCTO|  £IHP 


Now,  press  the  CulSlS  soft  menu  key,  to  get 


EDIT  1  CURS  1  EIG  -\  EVHL  |FflCTD|  SIMP 

Press  [  r>  J  wpo  to  recover  the  original  expression.  Next,  enter  the  following 

keystrokes:  ^^^CDCE?CDCDCDCDCDi^i^(:?:iC3CDto  select 
the  last  two  terms  in  the  expression,  i.e.. 


EDIT  I  CURS  I  EIG  ■!  EVHL  |FHCTD|  SIHR 


press  the  EEEiE]  soft  menu  key,  to  get 

x^+s.y.x+Y^BfflaaBHl 


EDIT  I  CURS  I  EIC  ■!  EVHL  |FHCTD|  SIHF 


Press  (j^l  woo  to  recover  the  original  expression.  Now,  let's  select  the  entire 
expression  by  pressing  the  upper  arrow  key  (i^an,  )  once.   And  press  the 
BTlSilS  soft  menu  key,  to  get 
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EDIT   CUR£   EIG  ■  EVAL  FACTO  £IHF 


Press  (jgjuvpoto  recover  the  original  expression. 


Note:  Pressing  the  I0ZEH  or  the  ISHB  soft  menu  keys,  while  the  entire  original 
expression  is  selected,  produces  the  following  simplification  of  the  expression: 


EDIT   CUR£   EIG  ■  EVAL  FACTO  £IHF 


Using  the  CMOS  menu  key 

With  the  original  polynomial  expression  used  in  the  previous  exercise  still 
selected,  press  the  [wxtJ  key  to  show  the  EIjH  and      IS  soft  menu  keys. 


These  two  commands  belong  to  the  second  part  of  the  soft  menu  available 
with  the  Equation  Writer.    Let's  try  this  example  as  an  application  of  the  MGEIa 
soft  menu  key:  Press  the  EISi  soft  menu  key  to  get  the  list  of  CAS  commands: 


CA£  c«HHondf: 

ARCUV 

ACDSaS 

ADDTHDD 

ADDTDREAL 

ALGE 

1         1         1  ICAnCL 

OK 

Next,  select  the  command  DERVX  (the  derivative  with  respect  to  the  variable  X, 
the  current  CAS  independent  variable)  by  using;  (^^(dI's^'sx?^^?  . 
Command  DERVX  will  now  be  selected: 


Press  the 


CA£  C«HHOndf: 

DEF 

DEGREE 
DERIV 

DERVX 

DEVOLVE 
DIAGHAP 

1         1         1  ICAnCL 

OK 

key 

{(jD  ),  to  get: 

DERVx[x^+2.V.X+V^-(o: 

CMDS 

IHELPI         1  1 
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Next,  press  the  [nxtJ  key  to  recover  the  original  Equation  Writer  menu,  and 
press  the  laililli  soft  menu  key  (C^O  )  to  evaluate  this  derivative.   The  result  is: 

I 


EDIT  I  CUR£  I  EIG  ■!  EVHL  |FHCTO|  £IHP 


Using  the  HELP  menu 

Press  the  [nxt)  key  to  shov/  the  SII3i  and  ElaB  soft  menu  keys.  Press  the  EESEi 

soft  menu  key  to  get  the  list  of  CAS  commands.  Then,  press  (^™)  (si 

to  select  the  command  DERVX.  Press  the  iSSI  soft  menu  key  (CKJ  ),  to  get 

information  on  the  command  DERVX: 
&ERVX: 

Returns  thie  deriyatiye 
withi  respect  to  thie 
current  variable 

-2.^tx-^2-n 

See:  DERIV  IHTVX 


EXIT  I  ECHO  I  f  EEl  |  £EE2  |  iZZ3  \  HHIH 


Detailed  explanation  on  the  use  of  the  help  facility  for  the  CAS  is  presented  in 
Chapter  1 .  To  return  to  the  Equation  Writer,  press  the  iLitliiEli  soft  menu  key. 
Press  the  [intb^}  key  to  exit  the  Equation  Writer. 

Using  the  editing  functions  BEGIN,  END,  COPY,  CUT  and  PASTE 

To  facilitate  editing,  whether  with  the  Equation  Writer  or  on  the  stack,  the 
calculator  provides  five  editing  functions,  BEGIN,  END,  COPY,  CUT  and 
PASTE,  activated  by  combining  the  right-shift  key  (CrL3)  with  keys  (2,1 ),  (2,2), 
(3,1),  (3,2),  and  (3,3),  respectively.   These  keys  are  located  in  the  leftmost 
part  of  rows  2  and  3.  The  action  of  these  editing  functions  are  as  follows: 

BEGIN:  marks  the  beginning  of  a  string  of  characters  for  editing 
END:    marks  the  ending  of  a  string  of  characters  for  editing 
COPY:   copies  the  string  of  characters  selected  by  BEGIN  and  END 
CUT:     cuts  the  string  of  characters  selected  by  BEGIN  and  END 
PASTE:  pastes  a  string  of  characters,  previously  copied  or  cut,  into  the  current 
cursor  position 

To  see  and  example,  lets  start  the  Equation  Writer  and  enter  the  following 
expression  (used  in  an  earlier  exercise): 
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CDCD  CxD  CS—tN  (^C5D(g  C+D  CX)  CHD  (4™iCED(gl  CED  (^CED© 
The  original  expression  is  the  following: 


^34 


EDIT   CUR£   EIG  ■  EVHL  FHCTO  £IHP 


We  wont  to  remove  the  sub-expression  x+2-A-Ay  from  the  argument  of  the  LN 
function,  and  move  it  to  the  right  of  the  A  in  the  first  term.  Here  is  one 
possibility:  ^CSDODCiD^^^^rJ^CiDCD^^^-m 
The  modified  expression  looks  as  follov/s: 


Next,  we'll  copy  the  fraction  2/ vS  from  the  leftmost  factor  in  the  expression, 
and  place  it  in  the  numerator  of  the  argument  for  the  LN  function.  Try  the 
following  keystrokes: 

^  ^  C3D  CD  ^  C3  ^  ^  ^ 

CZD  CD  C3D  CD  CD  C3 
The  resulting  screen  is  as  follows: 


EDIT   CUR£   EIG  ■  EVHL  FHCTD  £IHP 


The  functions  BEGIN  and  END  are  not  necessary  when  operating  in  the 
Equation  Writer,  since  we  can  select  strings  of  characters  by  using  the  arrow 
keys.  Functions  BEGIN  and  END  are  more  useful  when  editing  an  expression 
with  the  line  editor.  For  example,  let's  select  the  expression  x+2-A-Ay  from  this 
expression,  but  using  the  line  editor  within  the  Equation  Writer,  as  follows: 

The  line  editor  screen  will  look  like  this  (quotes  shown  only  if  calculator  in  RPN 
mode): 
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'  2^-J"3*^.*<x+2*S.*iy>  + 
EXP  ( -w.  >  *LH  ( 2/-J"3/e ( 1  / 
3>>  ' 


+^KIP|SKIP^  H)EL  I  DEL-f|DEL  L|  inS  ■ 


To  select  the  sub-expression  of  interest,  use: 

CV3  CD  CD  CD  CD  CD  CD  CD  CS  J™ 
CD  CD  CD  CD  CD  CD  CD  CD  CD  CD  ^ 
The  screen  shows  the  required  sub-expression  highlighted: 


XP  ( -iJt  >  *L™2/T5/?^(  1 


+^KIP|SKIP-H  H)EL  I  DEL-f|DEL  L|  inS  ■ 


We  can  now  copy  this  expression  and  place  it  in  the  denominator  of  the  LN 
argument,  as  follows:CE3-5^CDCD  ...  (27  times)  ...  CD 
C1DC5D...  (9  times)  ...  C±)  CEI1J«5 
The  line  editor  now  looks  like  this: 

..*tx-H2*^.*iy>-H 


+^KIP|SKIP-H  H)EL  I  DEL-f|DEL  L|  inS  ■ 


Pressing  [waj  shows  the  expression  in  the  Equation  Writer  (in  small-font  format, 
press  the  BIur«~]  soft  menu  key): 


EDITlCUR^I  EIG  |  EVHL  |FHCTO|  £IHP 


Press  [INTER}  to  exit  the  Equation  Writer. 


Creating  and  editing  summations,  derivatives,  and  integrals 

Summations,  derivatives,  and  integrals  are  commonly  used  for  calculus, 

probability  and  statistics  applications.  In  this  section  we  show  some  examples 
of  such  operations  created  with  the  equation  writer.  Use  ALG  mode. 

Summations 

We  will  use  the  Equation  Writer  to  enter  the  following  summation: 
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Press  (j^l  EQw  to  activate  the  Equation  Writer.  Then  press  LiU  5  to  enter 

the  summation  sign.  Notice  that  the  sign,  when  entered  into  the  Equation 
Writer  screen,  provides  input  locations  for  the  index  of  the  summation  as  well 
as  for  the  quantity  being  summed.  To  fill  these  input  locations,  use  the 
following  keystrokes: 

(^™]      (3  (X)  CX]  03  CD  CX]  C±D  (4™)  ® 

The  resultinq  screen  is: 

I  ^ — ;  1 

k  =  lk 


EDIT  I  CUR£  I  EIG  ■!  EVHL  |FHCTO|  £IHP 


To  see  the  corresponding  expression  in  the  line  editor,  press  Lr^  and  the 
CfT)  soft  menu  key,  to  show: 


st:k=i,«' 

,  lyk'-zy  

H)EL  1  DEL-f|DEL  L|  inS  ■ 

This  expression  shows  the  general  form  of  a  summation  typed  directly  in  the 
stack  or  line  editor: 

Z(/ncfex  =  starting_value,  ending_value,  summation  expression) 
Press  [waj  to  return  to  the  Equation  Writer.  The  resulting  screen  shows  the 
value  of  the  summation. 


EDIT   CURS   EIG  ■  EVflL  FflCTD  SIMP 


To  recover  the  unevaluated  summation  use  I    J  woo  .  To  evaluate  the 
summation  again,  you  can  use  the  ffT]  soft  menu  key.  This  shows  again  that 


CO  1 


2 

TT 


k^,k'  6 

You  can  use  the  Equation  Writer  to  prove  that 


00  1 


+00 

k 


This  summation  (representing  an  infinite  series)  is  said  to  diverge. 
Double  summations  are  also  possible,  for  example: 
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n  m 
j=lk=l 


j+k4 


EDIT   CURS   EIG  ■  EVflL  FflCTO  SIMP 


Derivatives 

We  will  use  the  Equation  Writer  to  enter  the  following  derivative: 

—{a-e  +  p-t  +  d) 
dt 

Press  (j^l  fOMf  to  activate  the  Equation  Writer.  Then  press  C3  ^  to  enter 

the  (partial)  derivative  sign.  Notice  that  the  sign,  when  entered  into  the 
Equation  Writer  screen,  provides  input  locations  for  the  expression  being 
differentiated  and  the  variable  of  differentiation.  To  fill  these  input  locations, 
use  the  following  keystrokes: 

(^™)     (S  CD  (^™)  CED  ®  CED     C5D  (3  CZD  ^ 

The  resulting  screen  is  the  following:  


hi 


] 


EDIT   CURS   EIG  ■  EVflL  FflCTD  SIMP 


To  see  the  corresponding  expression  in  the  line  editor,  press  Lr^  and  the 
CZD  soft  menu  key,  to  show:  


t^KIP  SKIP-H  H)EL   DEL-f  DEL  L  IDS  i 


This  indicates  that  the  general  expression  for  a  derivative  in  the  line  editor  or 
in  the  stack  is:  dvariable(function  of  variables) 


Press  [INTER]  to  return  to  the  Equation  Writer.  The  resulting  screen  is  not  the 
derivative  we  entered,  however,  but  its  symbolic  value,  namely. 


EDIT   CURS   EIG  ■  EVflL  FflCTD  SIMP 


To  recover  the  derivative  expression  use  "'^"o  .  To  evaluate  the  derivative 
again,  you  can  use  the  ffT]  soft  menu  key.  This  shows  again  that 
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—{a-t^  - P-t  +  d)  =  2a-t  +  p  . 

dt 

Second  order  derivatives  are  possible,  for  example: 


EDIT  I  CUR£  I  EIG  ■!  EVHL  |FHCTO|  SIW 


v/hich  evaluates  to: 


EDIT  I  CUR£  I  EIG  ■!  EVHL  |FHCTO|  SIW 


Note:  The  notation  — (  )  is  proper  of  partial  derivatives.  Tfie  proper 

dx 

notation  for  total  derivatives  (i.e.,  derivatives  of  one  varia  ble)  is  —  (  ).  Tfie 

dx 

calculator,  fiowever,  does  not  distinguisfi  between  partial  and  total 
derivatives. 


Definite  integrals 

We  will  use  the  Equation  Writer  to  enter  the  following  definite 

integral:  ^^t  ■  sin(/^)  •  dt .  Press  CS-^wf  to  activate  the  Equation  Writer. 

Then  press  C23   I  to  enter  the  integral  sign.  Notice  that  the  sign,  when 

entered  into  the  Equation  Writer  screen,  provides  input  locations  for  the  limits 
of  integration,  the  integrand,  and  the  variable  of  integration.  To  fill  these 
input  locations,  use  the  following  keystrol<es:[  0  jrT)l>iwyir»  J(iZirDl'^™4)  I  *n  J 
(tlfxlCavll^wi^C^ (3(^(^4^  .  The  resulting  screen  is  the  following: 


t'SIHCt^dt 

0 

EDIT  1  CURS  1  EIG     EVHL  |FflCTD|  SIMP 

To  see  the  corresponding  expression  in  the  line  editor,  press  (^(^^  and  the 
nn  soft  menu  key,  to  show: 
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/■t0,-T;,t*SIHa>,t> 


+^KIP  SKIP-H  *OZL   DEL-f  DEL  L  inS  i 


This  indicates  that  the  general  expression  for  a  derivative  in  the  line  editor  or 
in  the  stack  is:  j(lower_limit,  upper_limit,integrand,variable_of_infegration) 

Press  [INTER)  to  return  to  the  Equation  Writer.  The  resulting  screen  is  not  the 
definite  integral  we  entered,  however,  but  its  symbolic  value,  namely, 


EDIT   CUR£   EIG  ■  EVHL  FHCTD  £IHP 


To  recover  the  derivative  expression  use  [  r»  J  .  To  evaluate  the  derivative 
again,  you  can  use  the  ffH  soft  menu  key.  This  shov/s  again  that 

t  ■  sin(^)  •  dt  =  sin(r)  -  t  ■  cos(r) 
Double  integrals  are  also  possible.  For  example, 


^3 

Cx+y)dy  dx4 

-X 

-3 

EDIT 

1  CURS  1  EIG     EVflL  |FflCTD|  SIMP 

which  evaluates  to  36.    Partial  evaluation  is  possible,  for  example: 


3 

-3 

EDIT  1  CURS 

1  EIG  ■!  EVflL  IFflCTDI  SIMP 

This  integral  evaluates  to  36. 


Organizing  data  in  the  calculator 

You  can  organize  data  in  your  calculator  by  storing  variables  in  a  directory 
tree.  To  understand  the  calculator's  memory,  we  first  take  a  look  at  the  file 
directory.    Press  the  keystroke  combination  [jT]™k_  (first  key  in  second  row 
of  keys  from  the  top  of  the  keyboard)  to  get  the  calculator's  File  Manager 
screen: 
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9 : IRAN  2?3Ke 

L:ERAH 

a: FLASH 

This  screen  gives  a  snapshot  of  the  calculator's  memory  and  of  the  directory 
tree.  The  screen  shows  that  the  calculator  has  three  memory  ports  (or  memory 
partitions),  port  O:\RAM,  port  1  :ERAM,  and  port  2:FLASH  .  Memory  ports  are 
used  to  store  third  party  application  or  libraries,  as  well  as  for  backups.  The 
size  of  the  three  different  ports  is  also  indicated.  The  fourth  and  subsequent 
lines  in  this  screen  show  the  calculator's  directory  tree.  The  top  directory 
(currently  highlighted)  is  the  Home  directory,  and  it  has  predefined  into  it  a 
sub-directory  called  CASDIR.  The  File  Manager  screen  has  three  functions 
associated  with  the  soft-menu  keys: 

IlinilijI!?!  (pn  ):  Change  to  selected  directory 

mm  (Cjl)  ):  Cancel  action 

SuEli  (CKJ  )'•  Approve  a  selection 

For  example,  to  change  directory  to  the  CASDIR,  press  the  down-arrow  key, 

,  and  press  (CfD  )•  This  action  closes  the  File  Manager  window 

and  returns  us  to  normal  calculator  display.  You  will  notice  that  the  second 
line  from  the  top  in  the  display  now  starts  with  the  characters  {  HOME 
CASDIR  }  indicating  that  the  current  directory  is  CASDIR  within  the  HOME 
directory. 

Functions  for  manipulation  of  variables 

This  screen  includes  20  commands  associated  with  the  soft  menu  keys  that 
can  be  used  to  create,  edit,  and  manipulate  variables.  The  first  six  functions 
are  the  following: 

To  edit  a  highlighted  variable 
To  copy  a  highlighted  variable 

IIIIhSI  To  move  a  highlighted  variable 

nMS  To  recall  the  contents  of  a  highlighted  variable 

BI135  To  evaluate  a  highlighted  variable 

¥iSS  To  see  the  directory  tree  where  the  variable  is  contained 

If  you  press  the  C^D  key,  the  next  set  of  functions  is  made  available: 

mUSSI         To  purge,  or  delete,  a  variable 
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ii.L!.3.L!.L!.L!         lo  renoiTie  a  variable 
ijjjj  To  create  a  new  variable 

933333         To  order  a  set  of  variables  in  the  directory 
9a333  To  send  a  variable  to  another  calculator  or  computer 

MMB  To  receive  a  variable  from  another  calculator  or  computer 

If  you  press  the  [nxT)  key,  the  third  set  of  functions  is  made  available: 
933313  To  return  to  the  stack  temporarily 

sEiiill  To  see  contents  of  a  variable 

ilalMa         To  edit  contents  of  a  binary  variable  (similar  to  Qljlljl) 
933333         To  shov/  the  directory  containing  the  variable  in  the  header 
93[9§[i  Provides  a  list  of  variable  names  and  description 

To  sort  variables  according  to  a  sorting  criteria 

If  you  press  the  C^l)  key,  the  last  set  of  functions  is  made  available: 
^3333         To  send  variable  with  X-modem  protocol 
9333[93         To  change  directory 

To  move  between  the  different  soft  menu  commands,  you  can  use  not  only  the 

NEXT  key  (C^),  but  also  the  PREV  key  ((jjJ^M-  )■ 

The  user  is  invited  to  try  these  functions  on  his  or  her  own.  Their  applications 
are  straightforward. 

The  HOME  directory 

The  HOME  directory,  as  pointed  out  earlier,  is  the  base  directory  for  memory 
operation  for  the  calculator.  To  get  to  the  HOME  directory,  you  can  press  the 
UPDIR  function  ([j^updr_  )  -  repeat  as  needed  -  until  the  ■!.  HOME- .;■  spec  is 
shown  in  the  second  line  of  the  display  header.  Alternatively,  you  can  use 
LjiJ  (hold)  ™^  ,  press  (Jnje^  if  in  the  algebraic  mode.  For  this  example,  the 
HOME  directory  contains  nothing  but  the  CASDIR.  Pressing  L  vm  j  v/ill  show 
the  variables  in  the  soft  menu  keys: 


Subdirectories 

To  store  your  data  in  a  well  organized  directory  tree  you  may  want  to  create 
subdirectories  under  the  HOME  directory,  and  more  subdirectories  within 
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subdirectories,  in  a  hierarchy  of  directories  similar  to  folders  in  modern 
computers.  The  subdirectories  will  be  given  names  that  may  reflect  the 
contents  of  each  subdirectory,  or  any  arbitrary  name  that  you  can  think  of. 


The  CASDIR  sub-directory 

The  CASDIR  sub-directory  contains  a  number  of  variables  needed  by  the 
proper  operation  of  the  CAS  (Computer  Algebraic  System,  see  appendix  C). 
To  see  the  contents  of  the  directory,  we  can  use  the  keystroke  combination: 
[j=[]ffi£s_  which  opens  the  File  Manager  once  more: 


This  time  the  CASDIR  is  highlighted  in  the  screen.   To  see  the  contents  of  the 
directory  press  the  13111  (C^  )  soft  menu  key  or  (intek}^  to  get  the  following 
screen: 


0 

[R  HODULO 

IRTG 

G 

i  ^REALASSUHE 

LIST 

a? 

t(5f  PERIOD 

ALG 

12 

GRAHE 

H 

\R  EPJ 

REAL 

10 

EDIT  1  COPV  1  HOVE 

RCL  lEVAL 

TREE 

The  screen  shows  a  table  describing  the  variables  contained  in  the  CASDIR 
directory.  These  are  variables  pre-defined  in  the  calculator  memory  that 
establish  certain  parameters  for  CAS  operation  (see  appendix  C).   The  table 
above  contains  4  columns: 

•  The  first  column  indicate  the  type  of  variable  (e.g.,  'EQ'  means  an 
equation-type  variable,  |  R  indicates  a  real-value  variable,  { }  means  a  list, 
nam  means  'a  global  name',  and  the  symbol       represents  a  graphic 
variable. 

•  The  second  column  represents  the  name  of  the  variables,  i.e.,  PRIMIT, 
CASINFO,  MODULO,  REALASSUME,  PERIOD,  VX,  and  EPS. 

•  Column  number  3  shows  another  specification  for  the  variable  type,  e.g., 
ALG  means  an  algebraic  expression,  GROB  stands  for  graphics  object, 
INTG  means  an  integer  numeric  variable,  /./Simeons  a  list  of  data. 
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GNAME  means  a  global  name,  and  REAL  means  a  real  (or  floating-point) 
numeric  variable. 

•    The  fourth  and  last  column  represents  the  size,  in  bytes,  of  the  variable 

truncated,  without  decimals  (i.e.,  nibbles).  Thus,  for  example,  variable 
PERIOD  takes  12.5  bytes,  while  variable  REALASSUME  takes  27.5  bytes 
(1  byte  =  8  bits,  1  bit  is  the  smallest  unit  of  memory  in  computers  and 
calculators). 

CASDIR  Variables  in  the  stack 

Pressing  the  (.  on  J  key  closes  the  previous  screen  and  returns  us  to  normal 
calculator  display.  By  default,  we  get  back  the  TOOL  menu: 


EDIT  I  VIEH  I^THCKl  RCL  IPURGEICLEHR 


We  can  see  the  variables  contained  in  the  current  directory,  CASDIR,  by 

pressing  the  (j«J  key  (first  key  in  the  second  row  from  the  top  of  the 
keyboard).  This  produces  the  following  screen:  


PRIHI|CH£in|HODUL|REHLH|PERIO|  'K 


Pressing  the  [hxt]  key  shows  one  more  variable  stored  in  this  directory: 

•  To  see  the  contents  of  the  variable  EPS,  for  example,  use  [    JlliiSa.  This 
shows  the  value  of  EPS  to  be  .  8088i38i380 1 

•  To  see  the  value  of  a  numerical  variable,  we  need  to  press  only  the  soft 
menu  key  for  the  variable.  For  example,  pressing  !=!!!]  followed  by  Qntek}^ 
shows  the  same  value  of  the  variable  in  the  stack,  if  the  calculator  is  set  to 
Algebraic.  If  the  calculator  is  set  to  RPN  mode,  you  need  only  press  the 
soft  menu  key  for  [inter]  . 

•  To  see  the  full  name  of  a  variable,  press  the  apostrophe  first  CZD,  and 
then  the  soft  menu  key  corresponding  to  the  variable.  For  example,  for 
the  variable  listed  in  the  stack  as  PERIO,  we  use:  I  ■  jKaSBI,  which 
produces  as  output  the  string:  '  F-1~F?I0D  '  .  This  procedure  applies  to 
both  the  Algebraic  and  RPN  calculator  operating  modes. 

Variables  in  CASDIR 

The  default  variables  contained  in  the  CASDIR  directory  are  the  following: 
PRIMIT  Latest  primitive  (anti-derivative)  calculated,  not  a  default 
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variable,  but  one  created  by  a  previous  exercise 
CASINFO        a  graph  that  provides  CAS  information 
MODULO         Modulo  for  modular  arithmetic  (default  =  1 3) 
REALASSUME    List  of  variable  names  assumed  as  real  values 
PERIOD  Period  for  trigonometric  functions  (default  =  2n) 

VX  Name  of  default  independent  variable  (default  =  X) 

EPS  Value  of  small  increment  (epsilon),  (default  =  10'^°) 

These  variables  are  used  for  the  operation  of  the  CAS. 

Typing  directory  and  variable  names 

To  name  subdirectories,  and  sometimes,  variables,  you  v/ill  have  to  type 
strings  of  letters  at  once,  which  may  or  may  not  be  combined  v/ith  numbers. 
Rather  than  pressing  the  td™),  l^™j[JnJ,  or      (^i^JLiiJ  key  combinations  to 
type  each  letter,  you  can  hold  dov/n  the  [mpha]  key  and  enter  the  various  letter. 
You  can  also  lock  the  alphabetic  keyboard  temporarily  and  enter  a  full  name 
before  unlocking  it  again.  The  follov/ing  combinations  of  keystrokes  v/ill  lock 
the  alphabetic  keyboard: 

[ALPHA) [ALPHA}  locks  the  olphobetic  keyboard  in  upper  case.  When  locked  in  this 
fashion,  pressing  the  LjnJ  before  a  letter  key  produces  a  lower  case  letter, 
while  pressing  the  Is^J  key  before  a  letter  key  produces  a  special  character. 
If  the  alphabetic  keyboard  is  already  locked  in  upper  case,  to  lock  it  in  lower 
case,  type,  [  *i  }(AiM) 

[>jMA][wjA)ij^[wiA)  locks  the  alphabetic  keyboard  in  lower  case.  When  locked 
in  this  fashion,  pressing  the  I  <n  J  before  a  letter  key  produces  an  upper  case 
letter.  To  unlock  lower  case,  press  [  *-\  ][alpha) 

To  unlock  the  upper-case  locked  keyboard,  press  [alpha) 

Let's  try  some  exercises  typing  directory/ variable  names  in  the  stack. 
Assuming  that  the  calculator  is  in  the  Algebraic  mode  of  operation  (although 
the  instructions  work  as  well  in  RPN  mode),  try  the  following  keystroke 
sequences.  With  these  commands  we  will  be  typing  the  words  'MATH', 
'Math',  and  'MatH' 
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(g]  (fNTHj 
'(H}{ENm) 


[    ■   )lALPHA)lALPHAj(M}(A}  (f]  (h]  [eNTER) 

The  calculator  display  will  show  the  following  (left-hand  side  is  Algebraic 
mode,  right-hand  side  is  RPN  mode): 


:  'MATH' 

MRTH 

: 'Mat  hi' 

Matti 

:'MatH' 

 MatH 

EDIT  1  VIEH 

RCL  1  STO^  |PURGE|CLEflR 

7: 

6: 

5: 

4: 

3: 

' MRTH ' 

Z: 

'Mat  hi' 

l: 

'MatH' 

EDIT  1  VIEH  1  RCL 

1  ^^^!^  IF-URGEICLEHR 

Note:  if  system  flag  60  is  set,  you  can  lock  the  alphabetical  keyboard  by  just 
pressing  [alpha)  .    See  Chapter  1  for  more  information  on  system  flags. 


Creating  subdirectories 

Subdirectories  con  be  created  by  using  the  FILES  environment  or  by  using  the 
command  CRDIR.  The  two  approaches  for  creating  sub-directories  are 
presented  next. 

Using  the  FILES  menu 

Regardless  of  the  mode  of  operation  of  the  calculator  (Algebraic  or  RPN),  we 
can  create  a  directory  tree,  based  on  the  HOME  directory,  by  using  the 
functions  activated  in  the  FILES  menu.  Press  (JjJ%^  to  activate  the  FILES 
menu.  If  the  HOME  directory  is  not  already  highlighted  in  the  screen,  i.e.. 


 SISKD 


IRAH 
ERAH 
FLA^H 


use  the  up  and  down  arrow  keys  ((^5^'^^)  to  highlight  it.  Then,  press  the 
......i...  (fTT] )  soft  menu  key.  The  screen  may  look  like  this: 


HtHora:  3HHHS3  I 

r-=t™<na 


EDIT  I  CORY  I  HOVE  |  RCL  |  EVAL  |  TREE 
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showing  that  only  one  object  exists  currently  in  the  HOME  directory,  namely, 
the  CASDIR  sub-directory.    Let's  create  another  sub-directory  called  MANS 
(for  MANualS)  where  we  will  store  variables  developed  as  exercises  in  this 
manual.  To  create  this  sub-directory  first  enter:  Inxt)  IEISj!  (flT] )  .  This  will 
produce  the  following  input  form: 


TlEHVflRIflFLES 


EDIT  CHOOS 


The  Object  input  field,  the  first  input  field  in  the  form,  is  highlighted  by  default. 
This  input  field  can  hold  the  contents  of  a  new  variable  that  is  being  created. 
Since  we  have  no  contents  for  the  new  sub-directory  at  this  point,  we  simply 
skip  this  input  field  by  pressing  the  down-arrow  key,  "sj?,  once.  The  Name 
input  field  is  now  highlighted: 


HEH  VHRIHELE 
_  Dif sctory 


This  is  where  we  enter  the  name  of  the  new  sub-directory  (or  variable,  as  the 
case  may  be),  as  follows:  (^t^(^i™)(g(2](N](?](Mffl) 


The  cursor  moves  to  the  _Directory  check  field.  Press  the  I'/SHl  (r«~l )  soft  menu 
key  to  specify  that  you  are  creating  a  directory,  and  press  PIEIili  to  exit  the 
input  form.    The  variable  listing  for  the  HOME  directory  will  be  shown  in  the 
screen  as  follows: 


The  screen  indicates  that  there  is  a  new  directory  (MANS)  within  the  HOME 
directory. 
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Next,  we  will  create  a  sub-directory  named  INTRO  (for  INTROduction),  within 
MANS,  to  hold  variables  created  as  exercise  in  subsequent  sections  of  this 
chapter.  Press  the  I  (m  j  key  to  return  to  normal  calculator  display  (the  TOOLS 
menu  will  be  shown).  Then,  press  tjwj  to  show  the  HOME  directory  contents 
in  the  soft  menu  key  labels.  The  display  may  look  like  this  (if  you  have 
created  other  variables  in  the  HOME  directory  they  will  show  in  the  soft  menu 
key  labels  too): 


To  move  into  the  MANS  directory,  press  the  corresponding  soft  menu  key 
(CZD  in  this  case),  and  (a™]  if  in  algebraic  mode.  The  directory  tree  will  be 
shown  in  the  second  line  of  the  display  as  •.  HOriE  MRHS}  .    However,  there 
will  be  no  labels  associated  with  the  soft  menu  keys,  as  shown  below, 
because  there  are  no  variables  defined  within  this  directory. 
Let's  create  the  sub-directory  INTRO  by  using: 

HLES_  lyllii  (nXT)  MMM  {MPHA}  (ALPHAj  (J]  (N\  (f]  (R]  (5]  (mo)  "s^ESS  SuESI 

Press  the  I  on  J  key,  followed  by  the  I  vm  J  key,  to  see  the  contents  of  the  MANS 
directory  as  follows: 

Press  the  SjlCEd  soft  menu  key  to  move  into  the  INTRO  sub-directory.  This  will 
show  an  empty  sub-directory.  Later  on,  we  will  do  some  exercises  in  creating 
variables. 


Using  the  command  CRDIR 

The  command  CRDIR  can  be  used  to  create  directories.  This  command  is 
available  through  the  command  catalog  key  (the  (j:^!  cat  key,  second  key  in 
fourth  row  of  keys  from  the  top  of  the  keyboard),  through  the  programming 
menus  (the  ( Jn^l f^c    key,  same  key  as  the  I  r»  J  cat  key),  or  by  simply  typing  it. 

•  Through  the  catalog  key 

Press  I  r»  J_«z:  (^^g] .  Use  the  up  and  down  arrow  keys  (/a\^^)  to 
locate  the  CRDIR  command.  Press  the  ESSS  soft  menu  key  to  activate  the 
command. 

•  Through  the  programming  menus 

Press  L  *i  J^g    .  This  will  produce  the  following  pull-down  menu  for 
programming: 
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PROG  HEnU 

l.JTflCK..  1 

2.HEH0RY.. 
?.PRHnCH.. 
H.TEST.. 
5.  TYPE.. 
e.LIST.. 

1    1  1 

ICHnCL 

OK 

Use  the  down  arrow  key       )  to  select  the  option  2.  MEMORY...  ,  or  just 
press  I  2  J  ■  Then,  press  iESlS.  This  will  produce  the  following  pull-down 
menu: 


Use  the  down  arrow  key 
press  I  5  J .  Then,  press 
menu: 


MEMORY  HERU 


2.  MEM 

3.  PYTES 
H.REHOP 

5. DIRECTORY.. 
ARITHMETIC.. 


to  select  the  5.  D//?ECTO/?y  option,  or  just 
This  will  produce  the  following  pull-down 


DIRECTORY  MERU 

1. PURGE  1 

2.RCL 

3.ST0 

H.PflTH 

5.CRDIR 

C.PGDIR  1 

1       1       1  IcflncL 

OH 

Use  the  down  arrow  key  (^^)  to  select  the  5.  CRDIR  option,  and  press 


Command  CRDIR  in  Algebraic  mode 

Once  you  have  selected  the  CRDIR  through  one  of  the  means  shown  above, 
the  command  will  be  available  in  your  stack  as  follows: 


CRDIRO 


At  this  point,  you  need  to  type  a  directory  name,  say  chap]  : 

(^Z™)  (^ira)  (3^nJ  I^Z™]      (fl]  g]  (p][_J_J[UMf^(EMTER] 

The  name  of  the  new  directory  will  be  shown  in  the  soft  menu  keys,  e.g., 
F  UKDlKl'chapl'J  I 
HOVRL 
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Command  CRDIR  in  RPN  mode 

To  use  the  CRDIR  in  RPN  mode  you  need  to  hove  the  name  of  the  directory 

already  available  in  the  stack  before  accessing  the  command.  For  example: 

I^Z™]  [^1^ Q^nJ  [IZ™)  g]  (ff)  gl  (Jl  [_2_J  (^™) 

Then  access  the  CRDIR  command  by  either  of  the  means  shown  above,  e.g.. 


Press  the 
directory: 


6: 
5: 
4: 
3: 
2: 
l: 

CHTALOG:  COHHAnDS 

CRDIR  II 

CROSS 

CSHF 

CURL 

CVCLOTOMIC 
CVLin 

P2' 

1       1       1  IcflncL 

OK 

<ey  to  activate  the  command. 

chopai  SH 


Moving  among  subdirectories 

To  move  down  the  directory  tree,  you  need  to  press  the  soft  menu  key 
corresponding  to  the  sub-directory  you  want  to  move  to.  The  list  of  variables 
in  a  sub-directory  can  be  produced  by  pressing  the  [  w«  J  (VARiables)  key.  To 
move  up  in  the  directory  tree,  use  the  function  UPDIR,  i.e.,  enter  L  <i  j™  . 

Alternatively,  you  can  use  the  FILES  menu,  i.e.,  press  [  <n  Jff^g  .  Use  the  up 
and  down  arrow  keys  ((^'^y? )  to  select  the  sub-directory  you  want  to  move 
to,  and  then  press  the  CalliMli  (CHange  DIRectory)  or  ffH  soft  menu  key.  This 
will  show  the  contents  of  the  sub-directory  you  moved  to  in  the  soft  menu  key 
labels. 


Deleting  subdirectories 

To  delete  a  sub-directory,  use  one  of  the  following  procedures: 
Using  the  FILES  menu 

Press  the  [jT3™M_  key  to  trigger  the  FILES  menu.  Select  the  directory 
containing  the  sub-directory  you  want  to  delete,  and  press  the  HlilHa  if  needed. 
This  will  close  the  FILES  menu  and  display  the  contents  of  the  directory  you 
selected.    In  this  case  you  will  need  to  press       .    Press  the  SuHBI  soft  menu 
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key  to  list  the  contents  of  the  directory  in  the  screen.  Select  the  sub-directory 
(or  variable)  that  you  want  to  delete.  Press  [NXTjuSMs.  A  screen  similar  to  the 
following  will  be  shown: 


'S2' 

Are  Vou  Sure? 


The  'S2'  string  in  this  form  is  the  name  of  the  sub-directory  that  is  being 
deleted.    The  soft  menu  keys  provide  the  following  options: 
Elll      (CjD  )    Proceed  with  deleting  the  sub-directory  (or  variable) 
SilJIisll      (QD  )    Proceed  with  deleting  all  sub-directories  (or  variables) 

(fHl )    Do  not  delete  sub-directory  (or  variable)  from  a  list 
SES3E      (ffT] )    Do  not  delete  sub-directory  (or  variable) 
After  selecting  one  of  these  four  commands,  you  will  be  returned  to  the  screen 
listing  the  contents  of  the  sub-directory.  The  jjIiEIilil  command,  however,  will 
show  an  error  message:^    


0 

A  Interrupted 

and  you  will  have  to  press  KliS,  before  returning  to  the  variable  listing. 
Using  the  command  PGDIR 

The  command  PGDIR  can  be  used  to  purge  directories.  Like  the  command 
CRDIR,  the  PGDIR  command  is  available  through  the  I  r»  J  cat  or  through  the 
I  *i  ji^    key,  or  it  can  simply  be  typed  in. 

•  Through  the  catalog  key 

Press  (.  J_cg  {MfH^[MM}(p\(G] .  This  should  highlight  the  PGDIR  command. 
Press  the  SulIS  soft  menu  key  to  activate  the  command. 

•  Through  the  programming  menus 

Press  [jT]??c_  .  This  will  produce  the  following  pull-down  menu  for 
programming: 
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PROG  HEnU 

l.JTflCK..  1 

2.HEH0RY.. 

^.ERHnCH.. 

H.TEST.. 

5.  TYPE.. 

e.LIST.. 

Use  the  down  arrow  key       )  to  select  the  option  2.  MEMORY...  Then, 


HEHORY  HERU 

1. PURGE  II 

2.HEH  1 

3.PYTES  1 

H.REHOP  1 

5. DIRECTORY.. 

ARITHMETIC.  [| 

1      1      1  IchtklT 

OK 

Use  the  down  arrow  key  C^^? )  to  select  the  5.  DIRECTORY  opWon.  Then, 
press  nI3.  This  will  produce  the  following  pull-down  menu: 


DIRECTORY  HERU 


2.RCL 

3.ST0 

H.PflTH 

5.CRDIR 

e.PGDIR 


Use  the  down  arrow  key  (^^)  to  select  the  6.  PGDIR  option,  and  press 


Command  PGDIR  in  Algebraic  mode 

Once  you  have  selected  the  PGDIR  through  one  of  the  means  shown  above, 
the  command  will  be  available  in  your  stack  as  follows: 


PGDIRO 


At  this  point,  you  need  to  type  the  nome  of  on  existing  directory,  say  54  : 

[ALmA](s]  [  4  ][enter] 

As  a  result,  sub-directory  IIBIl  is  deleted:  


PGDIR('S4') 


HOVflL 


Instead  of  typing  the  name  of  the  directory,  you  can  simply  press  the 
corresponding  soft  menu  key  at  the  listing  of  the  PGDIR( )  command,  e.g.. 
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CHTALOG:  COHHAnD^ 

PERH 

PEVflL 

PGDIR 

PICK 

:PG 

PICK3 

PICT 

VRL 

1       1       1  IcflncL 

OK 

Press  Eiill,  to  get: 


:PGDIR('S4') 

HOVRL 

PGDIRO 

Then,  press  SaSB  to  enter  'S3'  as  the  argument  to  PGP 


:PGDIR('S4') 

HOVRL 

PGDIRCSS^ 

Press  [fwraj  to  delete  the  sub-directory: 


:PGDIR('S4') 

HOVRL 

:PGDIR('S3') 

HOVRL 

Command  PGDIR  in  RPN  mode 

To  use  the  PGDIR  in  RPN  mode  you  need  to  have  the  name  of  the  directory, 
between  quotes,  already  available  in  the  stack  before  accessing  the  command. 
For  example:     [  '  ][au>ha](s]1  2  Kenter} 

Then  access  the  PGDIR  command  by  either  of  the  means  shown  above,  e.g.. 


6: 
5: 
4: 
3: 
Z: 
l: 

CATALOG:  COHHAAD^ 

S2' 

PERH 
PEVflL 

PGDIR 

PICK 

PICK3 

PICT 

1       1       1  IcflncL 

OK 

Press  the  SuSS  soft  menu  key  to  activate  the  command  and  delete  the  sub- 
directory: 
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Using  the  PURGE  command  from  the  TOOL  menu 

The  TOOL  menu  is  available  by  pressing  the  Itool]  key  (Algebraic  and  RPN 
modes  shown): 


EDIT   VIEH  ^THCK   RCL   PURGE  CLEHR 


EDIT   VIEH  ^THCK   RCL   PURGE  CLEHR 


The  PURGE  command  is  available  by  pressing  the  ICEEBil  soft  menu  key 
In  the  follov^ing  examples  we  want  to  delete  sub-directory  SI: 

•  Algebraic  mode:    Enter  iijiijJMil  (j«sji:0llit£wraj 

•  RPN  mode:  Enter  [w<ij(.  ■  ]SSlcNTER)ljddL]miMsC^ 


Variables 

Variables  are  like  files  on  a  computer  hard  drive.  One  variable  can  store  one 
object  (numerical  values,  algebraic  expressions,  lists,  vectors,  matrices, 
programs,  etc).  Even  sub-directories  can  be  through  of  as  variables  (in  fact,  in 
the  calculator,  a  subdirectory  is  also  a  type  of  calculator  object). 

Variables  are  referred  to  by  their  names,  which  can  be  any  combination  of 
alphabetic  and  numerical  characters,  starting  with  a  letter  (either  English  or 
Greek).  Some  non-alphabetic  characters,  such  as  the  arrow  (-^)  can  be  used 
in  a  variable  name,  if  combined  with  an  alphabetical  character.  Thus,  '^A' 
is  a  valid  variable  name,  but       is  not.  Valid  examples  of  variable  names 
are:  'A',  'B',  'a',  'b',  'a',  'p',  'AT,  'AB12',  '^Al  2','Vel','Z0','zl ',  etc. 

A  variable  can  not  have  the  same  name  than  a  function  of  the  calculator.  You 
can  not  have  a  SIN  variable  for  example  as  there  is  a  SIN  command  in  the 
calculator.  The  reserved  calculator  variable  names  are  the  following: 
ALRMDAT,  CST,  EQ,  EXPR,  lERR,  lOPAR,  MAXR,  MINR,  PICT,  PPAR,  PRTPAR, 
VPAR,  ZPAR,  der_,  e,  i,  nl,n2,      si,  s2,      SDAT,  SPAR,  n,  « 

Variables  can  be  organized  into  sub-directories. 

Creating  variables 

To  create  a  variable,  we  can  use  the  FILES  menu,  along  the  lines  of  the 
examples  shown  above  for  creating  a  sub-directory.  For  example,  within  the 
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sub-directory  i  HOME  MflNS  INTRO),  created  in  an  earlier  example,  we 
want  to  store  the  following  variables  with  the  values  shown: 


Name 

Contents 

Type 

A 

12.5 

real 

a 

■0.25 

real 

A12 

3x105 

real 

Q 

'r/(m+r)' 

algebraic 

R 

[3,2,1] 

vector 

zl 

3+5i 

complex 

Pl 

«      r  '7i*r'^2'  » 

program 

Using  the  FILES  menu 

We  will  use  the  FILES  menu  to  enter  the  variable  A.  We  assume  that  we  are 
in  the  sub-directory  {  HOME  MRHS  INTF:;05  ,.  To  get  to  this  sub-directory, 
use  the  following:  [  <n  jFiifs  and  select  the  INTRO  sub-directory  as  shown  in 
this  screen: 


L:ERAH 

3:FLA£H 

hHAn^ 

CHDIRI         1         1         ICAnCLI  OK 

Press  IEI3S  to  enter  the  directory.  You  will  get  a  files  listing  with  no  entries 
(the  INTRO  sub-directory  is  empty  at  this  point) 


EDIT   COPV   HOVE    RCL    EVflL  TREE 


Press  the  Inxt)  key  to  move  to  the  next  set  of  soft  menu  keys,  and  press  the 
SEIuS  soft  menu  key.   This  will  produce  the  NEW  VARIABLE  input  form: 


REM  VARIARLE^ 


_  Dif sctory 
ztitir  niH  Object 


EDIT  CH003 


CAnCL  OK 
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To  enter  variable  A  (see  table  above),  v/e  first  enter  its  contents,  namely,  the 
number  1  2.5,  and  then  its  name.  A,  as  follov/s:  [  /  JL  2  Jl  •  Jl  5  J 
SESSS  [ALPHAS (A]WS}M.  Resulting  in  the  following  screen: 


Jbj<tt:  12.5 


Press  lildiiionce  more  to  create  the  variable.  The  new  variable  is  shown  in  the 
following  variable  listing: 


PURGElREnHHl  nEH  |ORDER|  ^EHD  |  RECV 


The  listing  indicates  a  real  variable  (|R),  whose  name  is  A,  and  that  occupies 
1 0.5  bytes  of  memory.   To  see  the  contents  of  the  variable  in  this  screen, 
press  (WjlsT" 

•     Press  the  liiiiiiiiij  ((jL) )  soft  menu  key  to  see  the  contents  in  a  graphical 
format. 

1275 


•  Press  the  HISj  ((jl)  )  soft  menu  key  to  see  the  contents  in  text  format. 

•  Press  lilljllito  return  to  the  variable  list 

•  Press  (.  ON  J  once  more  to  return  to  normal  display.  Variable  A  should  now 
be  featured  in  the  soft  menu  key  labels: 


Using  the  STO  ^  command 

A  simpler  way  to  create  a  variable  is  by  using  the  STO  command  (i.e.,  the 
[STO)  key).  We  provide  examples  in  both  the  Algebraic  and  RPN  modes,  by 
creating  the  remaining  of  the  variables  suggested  above,  namely: 
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Name 

Contents 

Type 

a 

■0.25 

real 

A12 

3x10^ 

real 

Q 

'r/(m+r)' 

algebraic 

R 

[3,2,1] 

vector 

zl 

3+5i 

complex 

Pl 

«      r  'n*T^T  » 

program 

•    Algebraic  mode 

Use  the  following  keystrokes  to  store  the  value  of  -0.25  into  variable 
a:  CODGDCIDCIDC^  (i^  (d^CEDSl  •  AT  this  point,  the  screen 
v/ill  look  as  follov/s:  

This  expression  means  that  the  value  -0.25  is  being  stored  into  a  (the 
symbol  ►  suggests  the  operation).  Press  ImhJ  to  create  the  variable. 
The  variable  is  now  shown  in  the  soft  menu  key  labels: 

The  following  are  the  keystrokes  required  to  enter  the  remaining 
variables: 

A12:  QDC^C5l)(irot](^t™)(3QI]CID(^ 

Q:  GDl^SDOCiDCSD'^ 

R:  CSD^LCTDCTE]  jCTDCiD  ;CTD(X)  [^i^i^®^^ 

zl :  CTDCTDCTDCXDCiD  j       (sror)(^(3)(|](X](wra)  (if  needed, 

accept  change  to  Complex  mode) 

pl:  QD^^Cr^^l^t^CfDlSCZJCfDj  CxJ 

(^QDOCZDCTDCDCDCD  C£rot)(^C5D(gCD(^.. 
The  screen,  at  this  point,  will  look  as  follows: 


m+r 

:[3  2  n>R 

[3  2  1] 

3+5.i 

:  «  r 
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You  will  see  six  of  the  seven  variables  listed  at  the  bottom  of  the 
screen:  pi,  zl,  R,  Q,  A12,  a. 


RPNmode 

Use  the  following  keystrokes  to  store  the  value  of  -0.25  into  variable 

ot:  C0~)  [  •  J  m  IS       )  ^Jnter)  [alpha]       (a]  jENTER] .  At  this  point,  the 
screen  will  look  as  follows; 


2: 

-.25 

l: 

'a' 

This  expression  means  that  the  value  -0.25  is  ready  to  be  stored  into 
a.  Press  (no^j  to  create  the  variable.  The  variable  is  now  shown  in 
the  soft  menu  key  labels: 


To  enter  the  value  3x1 0^  into  Al  2,  we  can  use  a  shorter  version  of 
the  procedure:  CT^C^CTir~'~l(^i^(A]CTlCTl(P^ 
Here  is  a  way  to  enter  the  contents  of  Q: 

Q:  CZDl^^lSDOCiDCS'^ 

To  enter  the  value  of  R,  we  can  use  an  even  shorter  version  of  the 
procedure: 

R:  [jjJU  LJJ L2_J LZ£J L_LJ (ID  L_lJI4™)(3  (wnx)[sror) 

Notice  that  to  separate  the  elements  of  a  vector  in  RPN  mode  we  can 

use  the  space  key  (ijf£j),  rather  than  the  comma  (I    J  j    )  used 

above  in  Algebraic  mode. 

zl :  CDCSCBCSCZDSD,^      dJl^OdlCTD  li^(if 

needed,  accept  change  to  Complex  mode) 

P 1 :  C3  ^  (d^)  SD  (3  CD  SD  ^  CHD 


The  screen,  at  this  point,  will  look  as  follows: 


l: 


You  will  see  six  of  the  seven  variables  listed  at  the  bottom  of  the 
screen:  pi,  zl,  R,  Q,  All,  a. 
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Checking  variables  contents 

As  an  exercise  on  peeking  into  the  contents  of  variables  we  will  use  the  seven 
variables  entered  in  the  exercise  above.  We  showed  how  to  use  the  FILES 
menu  to  view  the  contents  of  a  variable  in  an  earlier  exercise  when  we 
created  the  variable  A.  In  this  section  we  will  show  a  simple  way  to  look  into 
the  contents  of  a  variable. 

Pressing  the  soft  menu  key  label  for  the  variable 

This  procedure  will  show  the  contents  of  a  variable  as  long  as  the  variable 
contains  a  numerical  value  or  on  algebraic  value,  or  an  array.  For  example, 
for  the  variables  listed  above,  press  the  following  keys  to  see  the  contents  of 
the  variables: 

Algebraic  mode 

Type  these  keystrokes:  CW]!e3SI^S)  K3i(^s)IESS  Wm] .  At  this  point,  the 
screen  looks  as  follows: 


:  Zl 

:R 

[3  2  1] 

:Q 

r 

m+r 

Next,  type  these  keystrokes:  BEISil  Wer]  SEISS  [£nter]  Inxt]  BTSS  Wer]  .  At  this  point, 
the  screen  looks  as  follows: 


m+r 

:R12 

300000. 

:o: 

-.25 

:R 

12.5 

Pressing  the  soft  menu  key  corresponding  to  pJ  will  provide  an  error  message 
(try  (W]  iiniuSI  ): 


:o: 
:R 

300000. 

A  Error: 
Too  Few 
Arguments 

.25 
2.5 

:pl 

"Too  Few  Arguments" 
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Note:  By  pressing  :T':°:T  Qntek]  we  are  trying  to  activate  (run)  the  pi  program. 
However,  this  program  expects  a  numerical  input.  Try  the  following  exercise: 
[0N)'grSC5J(J_  (U(^ .  The  result  is: 


:pl(5) 

TT.25 

The  program  has  the  following  structure:  «  — >  r  'n*r'^2'  » 
The  -^K     symbols  indicate  a  program  in  User  RPL  language  (the  original 
programming  language  of  the  HP  28/48  calculators,  and  available  in  the  HP 
49G  series).  The  characters  — >  r  indicate  that  an  input,  to  be  referred  to  as  r, 
is  to  be  provided  to  the  program.  The  action  from  the  program  is  to  take  that 
value  of  r  and  evaluate  the  algebraic  'n*r^2' .  In  the  example  shown  above, 
rtook  the  value  of  5,  and  thus  the  value  of  nr^  =  n-25  is  returned.  This 
program,  therefore,  calculates  the  area  of  a  circle  given  its  radius  r. 

/IPNmot/e 

In  RPN  mode,  you  only  need  to  press  the  corresponding  soft  menu  key  label  to 
get  the  contents  of  a  numerical  or  algebraic  variable.  For  the  case  under 
consideration,  we  can  try  peeking  into  the  variables  z  J,  R,  Q,  A12,  a,  and  A, 
created  above,  as  follows:  MM  ISCS  SSS  SITEIBI ISSSS 


looks  like  this: 

[3  2  1] 

r 

m+r 

300000. 

11  

-.25 

To  see  the  contents  of  A,  use:  [nxt]  SSuII. 
To  run  program  pi  with  r  =  5,  use:  [wrj(_  5  J  WHL 


^  IJ 

5: 

r 

m+r 

4: 

300000. 

3: 

-.25 

2: 

12.5 

l: 

Ty25 

Notice  that  to  run  the  program  in  RPN  mode,  you  only  need  to  enter  the  input 
(5)  and  press  the  corresponding  soft  menu  key.  (In  algebraic  mode,  you  need 
to  place  parentheses  to  enter  the  argument). 
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Using  the  right-shift  key  L  r»  J  followed  by  soft  menu  key  labels 

This  approach  for  viewing  the  contents  of  a  variable  works  the  same  in  both 
Algebraic  and  RPN  modes.  Try  the  following  examples  in  either  mode: 

This  produces  the  following  screen  (Algebraic  mode  in  the  left,  RPN  in  the 
right) 


I.: 

«      r  '  Tr*r'^2 '  s- 

5: 

«      r  '  Tr*r'^2 '  ^ 

4: 

3+5.  i 

[3  2  1] 

3: 

[3  2  1] 

r 

2: 

r 

m+r 

m+r 

 3SSSSS. 

l: 

3SSSSS. 

Notice  that  this  time  the  contents  of  program  pi  are  listed  in  the  screen.  To 
see  the  remaining  variables  in  this  directory,  use: 

I       J lia^iii   INXT]  [       J  BUI 

Listing  the  contents  of  all  variables  in  the  screen 

Use  the  keystroke  combination  I  r»  JV^y  to  list  the  contents  of  all  variables  in 

the  screen.  For  example: 

bl:  -K      r  'Tr*r-^2. '  s- 
zl:  t3.,5.> 
R:  [3.,2.,1.] 

fll2:  300000. 
k:  -.25 


Press  L  on  J  to  return  to  normal  calculator  display. 
Replacing  the  contents  of  variables 

Replacing  the  contents  of  a  variable  can  be  thought  of  as  storing  a  different 
value  in  the  same  variable  name.  Thus,  the  examples  for  creating  variables 
shown  above  can  be  used  to  illustrate  the  replacement  of  a  variable's  content. 

Using  the  STO^  command 

Using  as  illustration  the  six  variables,  pi,  zl,  R,  Q,  A12,  a,  and  A,  created 
earlier,  we  will  proceed  to  change  the  contents  of  variable  A  72  (currently  a 
numerical  variable)  with  the  algebraic  expression  '|3/2',  using  the  STO^ 
command.  First,  using  the  Algebraic  operating  mode: 
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check  the  new  contents  of  variable  AT 2  by  using  I  r»  jiSIBji  . 
Using  the  RPN  operating  mode: 
or,  in  a  simplified  way, 

Using  the  left-shift  [jT]  key  followed  by  the  variable's  soft  menu  key  (RPN) 

This  is  a  very  simple  way  to  change  the  contents  of  a  variable,  but  it  only 
works  in  the  RPN  mode.  The  procedure  consists  in  typing  the  new  contents  of 
the  variable  and  entering  them  into  the  stack,  and  then  pressing  the  left-shift 
key  followed  by  the  variable's  soft  menu  key.  For  example,  in  RPN,  if  we 
want  to  change  the  contents  of  variable  zl  to  'a+b-i ',  use: 

This  will  place  the  algebraic  expression  'a+b-i '  in  level  ?;  in  the  stack.  To 
enter  this  result  into  variable  zl,  use:  [  w<!  Jl.  <n  )W3M 
To  check  the  new  contents  of  zl,  use:  L  r>  jBEHi 

An  equivalent  way  to  do  this  in  Algebraic  mode  is  the  following: 

To  check  the  new  contents  of  zl,  use:  L  r»  jBESi 

Using  the  ANS(1 )  variable  (Algebraic  mode) 

In  Algebraic  mode  one  can  use  the  ANS(1 )  variable  to  replace  the  contents  of 
a  variable.  For  example,  the  procedure  for  changing  the  contents  of  z  J  to 
'a+b/' is  the  following:      [J^ans_  [sro»J  ilSli  [enter] .  To  check  the  new 
contents  of  zl,  use:  (.  r»  J  KB 

Copying  variables 

The  following  exercises  show  different  ways  of  copying  variables  from  one 
sub-directory  to  another. 

Using  the  FILES  menu 

To  copy  a  variable  from  one  directory  to  another  you  can  use  the  FILES  menu. 
For  example,  within  the  sub-directory  {HOME  MANS  INTRO},  we  have 
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variables  pi,  zl,  R,  Q,  A12,  a,  and  A.  Suppose  that  we  want  to  copy 
variable  A  and  place  a  copy  in  sub-directory  {HOME  MANS}.  Also,  we  will 
copy  variable  /?  and  place  a  copy  in  the  HOME  directory.  Here  is  how  to  do 
it:  Press  t  <i  Jf/^^  lull!  to  produce  the  following  list  of  variables: 


[[]]R 
t(5f4 

[R  A12 

[R  « 

[R  A 


HATRK 

ALG 

REAL 

REAL 

REAL 


11 
11 
10 
10 
10 


EDIT   C0F-V   HOVE    RCL    EVAL  TREE 


Use  the  down-arrow  key       to  select  variable  A  (the  last  in  the  list),  then 
press  llililiiil.  The  calculator  will  respond  with  a  screen  labeled  PICK 
DESTINATION: 


PICK  DESTIAATIOn^^^ 

9 : IRAN 

L:ERAH 

3:FLA£H 

31CKR 

hHAA^ 

Use  the  up  arrow  key  to  select  the  sub-directory  MANS  and  press  iMllaS.  If 
you  now  press  [jT]t™_  ,  the  screen  will  show  the  contents  of  sub-directory 


MANS  (notice  that  varia 


Die  A  is  shown  in  this 


Press  IIliI 


(A 


ist,  as  expected): 
0 


[R  A 


REAL 


10 


EDIT   CORY   HOVE    RCL    EVAL  TREE 


Jgebraic  mode),  or  Lowj  IPr.'sr'°'='  (RPN  mode)  to  return 
to  the  INTRO  directory.  Press  [  <n  J fftf-s  iLlliI  to  produce  the  list  of  variables  in 
{HOME  MANS  INTRO}.  Use  the  down  arrow  key  (^ )  to  select  variable  /?, 
then  press  T::T::"?.  Use  the  up  arrow  key  (1^^ )  to  select  the  HOME  directory, 
and  press  iillli.  If  you  now  press  (.  <n  j™  ,  twice,  the  screen  will  show  the 
contents  of  the  HOME  directory,  including  a  copy  of  variable  /?: 


□CASDIR 


DIR 


EDIT  I  CORY  I  HOVE  |  RCL  |  EVAL  |  TREE 


Page  2-55 


Using  the  history  in  Algebraic  mode 

Here  is  a  way  to  use  the  history  (stack)  to  copy  a  variable  from  one  directory 
to  another  with  the  calculator  set  to  the  Algebraic  mode.  Suppose  that  we  are 
within  the  sub-directory  {HOME  MANS  INTRO},  and  want  to  copy  the 
contents  of  variable  zl  to  sub-directory  {HOME  MANS}.  Use  the  following 
procedure:  [    Jlil!j!j|y[?7o»j|||E!|n|||fA™]  This  simply  stores  the  contents  of  zl  into 
itself  (no  change  effected  on  zl).  Next,  use  [  *n  Jf™  Iintb^}  to  move  to  the 
{HOME  MANS}  sub-directory.  The  calculator  screen  will  look  like  this: 


:UPDIR 

HOVRL 

Next,  use  the  delete  key  three  times,  to  remove  the  last  three  lines  in  the 
display:  [  4  J  I    J  [  4  J .  At  this  point,  the  stack  is  ready  to  execute  the 
command  ANS(1  )^zl .    Press  [fAmsj  to  execute  this  command.  Then,  use 
I  r»  jlESII,  to  verify  the  contents  of  the  variable. 


Using  the  stack  in  RPN  mode 

To  demonstrate  the  use  of  the  stack  in  RPN  mode  to  copy  a  variable  from  one 
sub-directory  to  another,  we  assume  you  are  within  sub-directory  {HOME 
MANS  INTRO},  and  that  we  will  copy  the  contents  of  variable  zl  into  the 
HOME  directory.  Use  the  following  procedure:l    jiBSlf/vTiaJt  ■  jEltevTiEKj 
This  procedure  lists  the  contents  and  the  name  of  the  variable  in  the  stack. 


The  calculator  screen  wi 

1  look  like  this: 

l: 

'zl ' 

Now,  use  (33u™_  C5Di™-  to  move  to  the  HOME  directory,  and  press  droTi 
to  complete  the  operation.    Use  I  r»  J  Sail,  to  verify  the  contents  of  the  variable. 

Copying  two  or  more  variables  using  the  stack  in  Algebraic  mode 

The  following  is  an  exercise  to  demonstrate  how  to  copy  two  or  more 
variables  using  the  stack  when  the  calculator  is  in  Algebraic  mode.  Suppose, 
once  more,  that  we  are  within  sub-directory  {HOME  MANS  INTRO}  and  that 
we  want  to  copy  the  variables  /?and  Q  into  sub-directory  {HOME  MANS}. 
The  keystrokes  necessary  to  complete  this  operation  are  shown  following: 

CF3  i     droTl  iia  (enter) 
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{_r>_}  ill  iiiiilj  [sroT)  [ehtbi.] 
fjTI  ™«  [mm] 

C3D  cjj  ce  ^ 

To  verify  the  contents  of  tfie  variables,  use  I  r»  jHEl  and  L  r»  J  BIB. 

Tfiis  procedure  con  be  generalized  to  tfie  copying  of  tfiree  or  more  variables. 

Copying  two  or  more  variables  using  the  stack  in  RPN  mode 

The  follov/ing  is  on  exercise  to  demonstrate  hov/  to  copy  two  or  more 
variables  using  the  stock  v/hen  the  calculator  is  in  RPN  mode.  We  assume, 
again,  that  v/e  are  v/ithin  sub-directory  {HOME  MANS  INTRO}  and  that  v/e 
want  to  copy  the  variables  /?  and  Q  into  sub-directory  {HOME  MANS}.  The 
keystrokes  necessary  to  complete  this  operation  are  shown  following: 

To  verify  the  contents  of  the  variables,  use  [    JlllllLilll  and  L    J 110. 

This  procedure  can  be  generalized  to  the  copying  of  three  or  more  variables. 

Reordering  variables  in  a  directory 

In  this  section  we  illustrate  the  use  of  the  ORDER  command  to  reorder  the 
variables  in  a  directory.  We  assume  we  start  within  the  sub-directory  {HOME 
MANS}  containing  the  variables,  A  72,  /?,  Q,  z].  A,  and  the  sub-directory 
\H\RO,  as  shown  below.  (Copy  A1  2  from  INTRO  into  MANS). 


Algebraic  mode 

In  this  case,  we  have  the  calculator  set  to  Algebraic  mode.  Suppose  that  we 
want  to  change  the  order  of  the  variables  to  INTRO,  A,  zl,  Q,  R,  A12. 
Proceed  as  follows  to  activate  the  ORDER  function: 

[  <n  J^gg_  V^yEEB         Select  MEMORY  from  the  programming  menu 
'^^'^'^  SECSI     Select  DIRECTORY  from  the  MEMORY  menu 
(^(^  mm  Select  ORDER  from  the  DIRECTORY  menu 

The  screen  will  show  the  following  input  line: 
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Next,  we'll  list  the  new  order  of  the  variables  by  using  their  names  typed 
between  quotes: 


The  screen  now  shows  the  new  ordering  of  the  variab 


ORDER({'IHTRO'  'fl'  'zl'  'Q'  ► 
HOVRL 


es: 


RPN  mode 

In  RPN  mode,  the  list  of  re-ordered  variables  is  listed  in  the  stack  before 
applying  the  command  ORDER.  Suppose  that  we  start  from  the  same  situation 
as  above,  but  in  RPN  mode,  i.e., 


The  reordered  list  is  created  by  using: 


Then,  enter  the  command  ORDER,  as  done  before,  i.e., 
I  <n  Jfflg_  "sT^  jElU  Select  MEMORY  from  the  programming  menu 

^  ^  ^       SECSI     Select  DIRECTORY  from  the  MEMORY  menu 
C^C^  mm  Select  ORDER  from  the  DIRECTORY  menu 

The  result  is  the  following  screen: 


Moving  variables  using  the  FILES  menu 

To  move  a  variable  from  one  directory  to  another  you  can  use  the  FILES  menu. 
For  example,  within  the  sub-directory  {HOME  MANS  INTRO},  we  have 
variables  pi,  zl,  R,  Q,  A12,  a,  and  A.  Suppose  that  we  want  to  move 
variable  A 72  to  sub-directory  {HOME  MANS}.  Here  is  how  to  do  it:  Press 
[Jnj  2^  ilEliliiii  to  show  a  variable  list.  Use  the  down-arrow  key        to  select 
variable  A? 2,  then  press  li^^Jjii.  The  calculator  will  respond  with  a  PICK 


DESTINATION  screen.  Use  the  up  arrow  key  to  select  the  sub-directory 
MANS  and  press  The  screen  will  now  show  the  contents  of  sub- 

directory {HOME  MANS  INTRO}: 


Page  2-58 


t(5f3l  flLG  17 

[[]]R  HATRK  2? 

[R  A  REAL  10 


EDIT  I  CORY  I  HOVE  |  RCL  |  EVAL  |  TREE 


Notice  that  variable  Al  2  is  no  longer  there.    If  you  now  press  [jjJupok_  ^  the 
screen  will  show  the  contents  of  sub-directory  MANS,  including  variable  A12\^ 


H<A*ra:  3H3?3H  1 

0 

t(5f  Aia 

ALG 

IH 

[[]]R 

HATRK 

12 

t(5f4 

ALG 

2? 

t(5f3l 

ALG 

21 

[R  A 

REAL 

ID 

■    1  im  1 

DIR 

13? 

EDIT   COPV  HOVE 

RCL  EVAL 

TREE 

Note:  You  can  use  the  stack  to  move  a  variable  by  combining  copying  with 
deleting  a  variable.  Procedures  for  deleting  variables  are  demonstrated  in  the 
next  section. 


Deleting  variables 

Variables  con  be  deleted  using  function  PURGE.  This  function  can  be 
accessed  directly  by  using  the  TOOLS  menu  ((jooj),  or  by  using  the  FILES 
menu  LJnJ  fii-^^  sunw . 


Using  the  FILES  command 

The  FILES  command  can  be  used  to  purge  one  variable  at  a  time.  To  delete  a 
variable  from  a  given  directory  you  can  use  the  FILES  menu.  For  example, 
within  the  sub-directory  {HOME  MANS  INTRO},  we  have  variables  pi,  zl,  R, 
Q,  a,  and  A  left.  Suppose  that  we  delete  variable  A.  Here  is  how  to  do  it: 
Press  (.  «-i  J i^^iy  to  produce  the  variable  list.  Use  the  down-arrow  key 
to  select  variable  A  (the  last  in  the  list),  then  press  [WJIlIiIEHI  BilSI.  The 
screen  will  now  show  the  contents  of  sub-directory  IN 


*1\ 
[[]]R 

t(5f4 
[R  « 


HATRK 

ALG 

REAL 


RO  without  variable  A. 


EDIT   COPV   HOVE    RCL    EVAL  TREE 
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Using  function  PURGE  in  the  stack  in  Algebraic  mode 

We  start  again  at  subdirectory  {HOME  MANS  INTRO}  containing  now  only 
variables  pi,  zl,  Q,  R,  and  a.  We  will  use  command  PURGE  to  delete 
variable  p  7 .    Press  [rooj  Hllaiil  (.  vm  JlfSlI  [inter]  .    The  screen  will  now  show 
variable  p?  removed: 


:PURGE('pl') 

HOVRL 

You  can  use  the  PURGE  command  to  erase  more  than  one  variable  by  placing 
their  names  in  a  list  in  the  argument  of  PURGE.  For  example,  if  now  we 
wanted  to  purge  variables  R  and  Q,  simultaneously,  we  can  try  the  following 
exercise.  Press  : 

(Wi  naiEBiS  i3D!i_CD  C^lllillillCT)  CZD  !  CD  CHDIii^lil 

At  this  point,  the  screen  will  show  the  following  command  ready  to  be 
executed: 

iPURGECpl') 

HOVflL 

To  finish  deleting  the  variables,  press       .   The  screen  will  now  show  the 
remaining  variables: 


iRURGECpl') 

HOVRL 

:PURGE({'R'  'Q'» 

HOVRL 

Using  function  PURGE  in  the  stack  in  RPN  mode 

We  start  again  at  subdirectory  {HOME  MANS  INTRO}  containing  variables 
p],  z],  Q,  R,  and  a.  We  will  use  command  PURGE  to  delete  variable  p7. 
Press  CZDIiiitS  [f/vTHij  [Toaj  EEEEIiS.   The  screen  will  now  show  variable  pi 
removed: 


EDIT  I  VIEH  I^THCKl  RCL  IPURGEICLEHR 


To  delete  two  variables  simultaneously,  say  variables  R  and  Q,  first  create  a 
list  (in  RPN  mode,  the  elements  of  the  list  need  not  be  separated  by  commas 

as  in  Algebraic  mode):    Hm]   [JD  ««3&  CD  CU  BaS  Then, 

press  [ToajEDIHi  use  to  purge  the  variables. 
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UNDO  and  CMD  functions 

Functions  UNDO  and  CMD  are  useful  for  recovering  recent  commands,  or  to 
revert  an  operation  if  a  mistake  v/as  made.  These  functions  are  associated 
v/itfi  tfie  HIST  key:  UNDO  results  from  the  keystroke  sequence  [  r>  j  undo  ^  while 
CMD  results  from  the  keystroke  sequence  (.  *i  }cmd  . 

To  illustrate  the  use  of  UNDO,  try  the  following  exercise  in  algebraic  (ALG) 
mode:  CIDCEDCZI)C±DCID(^ .  The  UNDO  command  (C2I]_y«o)  v/ill 
simply  erase  the  result.  The  some  exercise  in  RPN  mode,  will  follow  these 
keystrokes:  [  5  Jlfl™)rTll«?'f/ijnni  3  Jlfl^lFH.  Using  fr^jjw  at  this  point 
will  undo  the  most  recent  operation  (20/3),  leaving  the  original  terms  back  in 
the  stack: 


£0 

l: 

3 

flECUV|CHinR|CYCLO|  Diva 

EGCD  IFflCTO 

To  illustrate  the  use  of  CMD,  let's  enter  the  following  entries  in  ALG  mode. 
Press  IcNTER]  after  each  entry. 


TflH(5.2) 
:SIH(3. 1) 
:J25 
:3J27 


HECUV  CHinR  CYCLO  EGCD  FHCTO 


Next,  use  the  CMD  function  ([  <n  }cmd  )  to  show  the  four  most  recent 
commands  entered  by  the  user,  i.e., 


:TF 

:SI 

Sin(3.1J 

:J? 

THn(5.2) 

1       1       1  icflncLl 

OK 

You  can  use  the  up  and  down  arrow  keys  {(^^^)  to  navigate  through  these 
commands  and  highlight  any  of  them  that  you  want  to  entry  anew.  Once  you 
have  selected  the  command  to  enter,  press  liillilli. 

The  CMD  function  operates  in  the  same  fashion  when  the  calculator  is  in  RPN 
mode,  except  that  the  list  of  commands  only  shows  numbers  or  algebraics.  It 
does  not  show  functions  entered.  For  example,  try  the  following  exercise  in 
RPN  mode: 

dD     CID  S  dD  S  CKD  ChD 
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Pressing  [  *i  Jp^o    produces  the  following  selection  box: 


=1 


As  you  can  see,  the  numbers  3,  2,  and  5,  used  in  the  first  calculation  above, 
are  listed  in  the  selection  box,  as  well  as  the  algebraic  'SIN(5x2)',  but  not  the 
SIN  function  entered  previous  to  the  algebraic. 

Flags 

A  flag  is  a  Boolean  value,  that  can  be  set  or  cleared  (true  or  false),  that 
specifies  a  given  setting  of  the  calculator  or  an  option  in  a  program.  Flags  in 
the  calculator  are  identified  by  numbers.  There  are  256  flags,  numbered  from 
-128  to  128.  Positive  flags  are  called  user  flags  and  are  available  for 
programming  purposes  by  the  user.  Flags  represented  by  negative  numbers 
are  called  system  flags  and  affect  the  way  the  calculator  operates. 
To  see  the  current  system  flag  setting  press  the  [mode]  button,  and  then  the 
liMiiiil!  soft  menu  key  (i.e.,  Fl).  You  will  get  a  screen  labeled  SYSTEM  FLAGS 
listing  flag  numbers  and  the  corresponding  setting. 

SSVSTEM  FLAGS S 


01  Qtncrol.  f^Luti^n; 


01  C^nftont  ■*  lynb 
03  Function  ■*  lynb 
IH  Po^Htnt  ot  «nd 
IS  -^a  ■*  veitir 
20  UndcrFLoH  ■*  0 
31  OmrFl ■>  ±3EH33 


(Note:  In  this  screen,  as  only  system  flags  are  present,  only  the  absolute  value 
of  the  flag  number  Is  displayed).  A  flag  is  said  to  be  set  if  you  see  a  check 
mark  ('^)  in  front  of  the  flag  number.  Otherwise,  the  flag  is  not  set  or  cleared. 
To  change  the  status  of  a  system  flag  press  the  ||/1|T|:I|!  soft  menu  key  while  the 
flag  you  want  to  change  is  highlighted,  or  use  the  [  J  key.  You  can  use  the 
up  and  down  arrow  keys  (^^^3? )  to  move  about  the  list  of  system  flags. 
Although  there  are  1  28  system  flags,  not  all  of  them  are  used,  and  some  of 
them  are  used  for  internal  system  control.  System  flags  that  are  not  accessible 
to  the  user  are  not  visible  in  this  screen.  A  complete  list  of  flags  is  presented 
in  Chapter  24. 
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Example  of  flag  setting:  general  solutions  vs.  principal  value 

For  example,  the  default  value  for  system  flag  01  is  General  solutions.  What 
this  means  is  that,  if  an  equation  has  multiple  solutions,  all  the  solutions  will  be 
returned  by  the  calculator,  most  likely  in  a  list.  By  pressing  the  j'/Slia  soft 
menu  key  you  can  change  system  flag  01  to  Principal  value.  This  setting  will 
force  the  calculator  to  provide  a  single  value  known  as  the  principal  value  of 
the  solution. 

To  see  this  at  work,  first  set  system  flag  01  (i.e.,  select  Principal  Value).  Press 
SEEli twice  to  return  to  normal  calculator  display.  We  will  try  solving  a 
quadratic  equation  solution,  say,  f+5\+6  =  0,  with  command  QUAD. 

Algebraic  mode 

Use  the  following  keystroke  sequence:  CS— £^  [aim^(q\  (use  the  up  and  down 
arrow  keys,  i^^Vry  ,  to  select  command  QUAD)  ,  press  iESl! . 

To  enter  the  equation  as  the  first  argument  of  function  QUAD,  use  the 

following  keystrokes: 

I  r»  J  ;  ^wm]  pTlitKai™) 

The  result  is: 

:QUflD(t^+5.t+6=0,t] 

Now,  change  the  setting  of  flag  1  to  General  solutions:  [mode] :'!:Y.:Y:1 
IKIiiuIII  illil ]ll  iLlEil .  And  try  the  solution  again:  ijHTER} [enter)  .  The  solution 

now  includes  two  values: 


:QURD(t^+5.t+6= 

t  = 

-3 

:QURD(t^+5't+6= 

 a 

=-2 

t=- 

3} 

/fPNmocfe 

First  set  system  flag  01  (i.e..  Principal  Value).  Press  1321  twice  to  return  to 
normal  calculator  display.   Then,  type  the  quadratic  equation  as  follows: 
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Ifwrsj  (keeping  a  second  copy  in  the  RPN  stack) 


4-- 

3: 

l: 

't  ' 

Use  the  following  keystroke  sequence  to  enter  the  QUAD  command: 
I  r^  J  CAT  [ALmA}(Q]  (use  the  up  and  down  arrow  keys,  ^^"^^  ,  to  select 
command  QUAD) ,  press  ElSS  .  The  screen  shows  the  principal  solution: 




3: 

Z: 

l: 

t=-3 

Now,  change  the  setting  of  flag  01   to  General  solutions:  (^w)H5iI33 

l!^Y!:Y  "ilT'TTllrr.  And  try  the  solution  again:  td™)  [3D(3[™^ 

Ir^J  cAT  iALPHA}(Q}    (usB  the  up  and  down  arrow  keys,  ,  to  select 

command  QUAD)  ,  press  1331 .  The  screen  now  shows  the  two  solutions: 


Other  flags  of  interest 

Bring  up  once  more  the  current  flag  setting  by  pressing  the  ImmJ  button,  and 
then  the  yliliSlsoft  menu  key.   Make  sure  to  clear  system  flag  01 ,  which  was 
left  set  from  the  previous  exercise.  Use  the  up  and  down  arrow  keys  {(^i"^^ ) 
to  move  about  the  system  flag  list. 

Some  flags  of  interest  and  their  preferred  value  for  the  purpose  of  the 
exercises  that  follow  in  this  manual  are: 

02  Constant  ->  symb:     Constant  values  (e.g.,  n)  are  kept  as  symbols 

03  Function  —^symb:     Functions  are  not  automatically  evaluated,  instead 

they  are  loaded  as  symbolic  expressions. 
27  'X+Y*i'     (X,Y):       Complex  numbers  are  represented  as  ordered  pairs 
60  [a][a]  locks:  The  sequence  (^™) [alpha)  locks  the  alphabetic  keyboard 

Press  lilSnl  twice  to  return  to  normal  calculator  display. 
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CHOOSE  boxes  vs.  Soft  MENU 

In  some  of  the  exercises  presented  in  this  chapter  we  have  seen  menu  lists  of 
commands  displayed  in  the  screen.  This  menu  lists  are  referred  to  as 
CHOOSE  boxes.  For  example,  to  use  the  ORDER  command  to  reorder 
variables  in  a  directory,  we  used: 

[^ffiG_  ^  Show  PROG  menu  list  and  select  MEMORY 


6: 
5: 

PROG  HEnU 

1. STACK..  1 

2.HEH0RY.. 

4: 
3: 
Z: 
l: 

?.RRAnCH.. 
H.TEST.. 
5.  TYPE.. 
e.LIST.. 

1         1  1 

ICAnCL 

OK 

^  ^  ^  ^    Show  the  MEMORY  menu  list  and  select  DIRECTORY 


6: 
5: 
4: 
3: 

HEHORY  HERU 

1.  PURGE 

2.  HEN 

3.  RYTES 
H.REHOR 

2: 
l: 

5. DIRECTORY.. 

ARITHMETIC..  | 

1         1         1  ICAnCL 

OK 

Show  the  DIRECTORY  menu 

7i 
6: 
5: 
4: 
3: 

DIRECTORY  HERU 

5.CRDIR  1 

C.PGDIR 

?.VARS 

S.TVARS 

2: 
l: 

3. ORDER 

10.  MEMORY..  1 

1         1         1  jCAnCL 

OK 

St  and  select  ORDER 


SEim  activate  the  ORDER  command 

There  is  an  alternative  way  to  access  these  menus  as  soii  MENU  keys,  by 

setting  flag  7  77.  To  set  this  flag  try  the  following: 

(mode)  ii:ii33§i     ^  ^  ^  ^  ^  ^ 

The  screen  shows  flag  1  ^  7  not  set  [CHOOSE  boxes),  as  shown  here: 


5SYSTEM  FLAGSJ 


11?  CHOOSE  boy.ll 


115  Ri3*r*uf  *ri 

120  SiUnt  HOd«  OFF 

12?  AU«H  Suitch  H«d« 

laE  Aciur.  Si^n-StucH 

136  rr«f  list 

/  lis  lifs  in  rtJlj 


Press  the  ii/SITIHSsoft  menu  key  to  set  flag  1 1 7  to  soft  MENU.  The  screen  wil 
reflect  that  change: 
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SVSTEM  FLflGS^ 


115  Ri3*r*uf  *ri 

130  £il.«n't  H«d«  iff 

127  AU4H  SuHch  Hod« 

las  flctur.  Sian-StufH 

126  rr«f  H-'  lajt  col 

/  IZg  Vjrj  in  rtjlj 


Press  twice  to  return  to  normal  calculator  display. 

Now,  we'll  try  to  find  the  ORDER  command  using  similar  keystrokes  to  those 
used  above,  i.e.,  we  start  with  [jT)??^  ■ 

Notice  that  instead  of  a  menu  list,  we  get  soft  menu  labels  with  the  different 
options  in  the  PROG  menu,  i.e.. 


£TACK   HEH    ERCH   TE^T   TYPE  LI^T 


Press  (jD  to  select  the  MEMORY  soft  menu  (BlHIBi). 


PURGE   HEH   RYTE£  REHOR   DIR  ARITH 


he  display  now  shows: 


Press  (jQ  to  select  the  DIRECTORY  soft  menu  (lEaSi) 


PURGE   RCL     STO    PATH  CRDIR  PGDIR 


The  ORDER  command  is  not  shown  in  this  screen.  To  find  it  we  use  the  Inxt) 
key  to  find  it: 


VAR£  TVAR£  ORDER 


To  activate  the  ORDER  command  we  press  the  C^D  i^MSS)  soft  menu  key. 
Although  not  applied  to  a  specific  example,  this  exercise  shows  the  two 
options  for  menus  in  the  calculator  (CHOOSE  boxes  and  soft  MENUs). 


Selected  CHOOSE  boxes 

Some  menus  will  only  produce  CHOOSE  boxes,  e.g., 

•     The  APRS  (APPlicationS  menu),  activated  with  the  Iapps]  key,  first  key  in 
the  second  row  of  keys  from  the  top  of  the  keyboard: 


l.PU-t  functi*nf.. 


2.1^<)  func'ti*nf.. 
^.C^nitiriti  lib.. 
H.nuH«ric  f*lu<r.. 
5.TiH«  &  iiti.. 
G.Equo'ti^n  Hrittr 


The  CAT  (CATalog  menu),  activated  with  the  [  J  cat^  key,  second 
key  in  the  fourth  row  of  keys  from  the  top  of  the  keyboard: 
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CHTALOG:  COHHAnD^ 

V. 

X 

1         1         1  ICHnCL 

OK 

•    The  HELP  menu,  activated  with  [joa}  Inxt)  EISM 


AECUV 

flcosas 

HDDTHOD 

HDDTOREAL 

HEL 

ALGE 

1       1       1  IcnncL 

OK 

•    The  CMDS  (CoMmanDS)  menu,  activated  v/ithin  the  Equation  Writer, 
i.e.,  Cr^_m  [w^lJ  MSM  


AECUV 

flcosas 

HDDTHOD 

HDDTOREAL 

ALGE 

1         1         1  ICHnCL 

OK 
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Chapter  3 

Calculation  with  real  numbers 

This  chapter  demonstrates  the  use  of  the  calculator  for  operations  and 
functions  related  to  real  numbers.   Operations  along  these  lines  are  useful  for 
most  common  calculations  in  the  physical  sciences  and  engineering.  The  user 
should  be  acquainted  with  the  keyboard  to  identify  certain  functions  available 
in  the  keyboard  (e.g.,  SIN,  COS,  TAN,  etc.).  Also,  it  is  assumed  that  the 
reader  knows  how  to  adjust  the  calculator's  operation,  i.e.,  select  operating 
mode  (see  Chapter  1 ),  use  menus  and  choose  boxes  (see  Chapter  1 ),  and 
operate  with  variables  (see  Chapter  2). 

Checking  calculators  settings 

To  check  the  current  calculator  and  CAS  settings  you  need  to  just  look  at  the 
top  line  in  the  calculator  display  in  normal  operation.  For  example,  you  may 
see  the  following  setting:  RAD  XYZ  DEC  R  =  'X' 

This  stands  for  RADians  for  angular  measurements,  XYZ  for  Rectangular 
(Cartesian)  coordinates,  DECimal  number  base.  Real  numbers  preferred,  = 
means  "exact"  results,  and  'X'  is  the  value  of  the  default  independent  variable. 

Another  possible  listing  of  options  could  be         DEG  RZZ  HEX  C  ~ 't' 

This  stands  for  DEGrees  as  angular  measurements,  RZZ  for  Polar  coordinates, 
HEXagesimal  number  base.  Complex  numbers  allowed,  ~  stands  for 
"approximate"  results,  and 't'  as  the  default  independent  variable. 

In  general,  this  part  of  the  display  contains  seven  elements.  Each  element  is 
identified  next  under  numbers  1  through  7.    The  possible  values  for  each 
element  are  shown  between  parentheses  following  the  element  description. 
The  explanation  of  each  of  those  values  is  also  shown: 
1 .   Angle  measure  specification  (DEG,  RAD,  GRD) 

DEG:  degrees,  360  degrees  in  a  complete  circle 

RAD:  radians,  2ti  radians  in  a  complete  circle 

GRD:  grades,  400  grades  in  a  complete  circle 
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2.  Coordinate  system  specification  (XYZ,  RZZ,  RZZ).    The  symbol  Z 
stands  for  an  angular  coordinate. 

XYZ:   Cartesian  or  rectangular  (x,y,z) 
RZZ:  cylindrical  Polar  coordinates  (r,0,z) 
RZZ:  Spherical  coordinates  (p,6,(|)) 

3.  Number  base  specification  (HEX,  DEC,  OCT,  BIN) 
HEX:    hexadecimal  numbers  (base  1 6) 

DEC:  decimal  numbers  (base  10) 
OCT:  octal  numbers  (base  8) 
BIN:    binary  numbers  (base  2) 

4.  Real  or  complex  mode  specification  (R,  C) 
R:       real  numbers 

C:      complex  numbers 

5.  Exact  or  approximate  mode  specification  (=,  ~) 
=        exact  (symbolic)  mode 

approximate  (numerical)  mode 

6.  Default  CAS  independent  variable  (e.g.,  'X',  't',  etc.) 

Checking  calculator  mode 

When  in  RPN  mode  the  different  levels  of  the  stack  are  listed  in  the  left-hand 
side  of  the  screen.  When  the  ALGEBRAIC  mode  is  selected  there  are  no 
numbered  stack  levels,  and  the  word  ALG  is  listed  in  the  top  line  of  the  display 
towards  the  right-hand  side.  The  difference  between  these  operating  modes 
was  described  in  detail  in  Chapter  1 . 

Real  number  calculations 

To  perform  real  number  calculations  it  is  preferred  to  have  the  CAS  set  to  Real 
(as  opposite  to  Complex]  mode.  In  some  cases,  a  complex  result  may  show 
up,  and  a  request  to  change  the  mode  to  Complex  will  be  made  by  the 
calculator.  Exaci  mode  is  the  default  mode  for  most  operations.  Therefore, 
you  may  want  to  start  your  calculations  in  this  mode.  Any  change  to  Approx 
mode  required  to  complete  an  operation  will  be  requested  by  the  calculator. 
There  is  no  preferred  selection  for  the  angle  measure  or  for  the  number  base 
specification.    Real  number  calculations  will  be  demonstrated  in  both  the 
Algebraic  (ALG)  and  Reverse  Polish  Notation  (RPN)  modes. 
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Changing  sign  of  a  number,  variable,  or  expression 

Use  the  I  *i-  J  key.  In  ALG  mode,  you  con  press  [  +/-  J  before  entering  the 
number,  e.g.,  l-^/-Jl  2  JPHl  5  Result  =  -2.5.  In  RPN  mode,  you  need 

to  enter  at  least  part  of  the  number  first,  and  then  use  the  [jtJ  key,  e.g., 
(■  2  J[  •  Jl  5  J[  +/-  J .  Result  =  -2.5.  If  you  use  the  I  +/-  J  function  while  there  is  no 
command  line,  the  calculator  will  apply  the  NEG  function  (inverse  of  sign)  to 
the  object  on  the  first  level  of  the  stack. 

The  inverse  function 

Use  the  I    J  key.  In  ALG  mode,  press  [    J  first,  followed  by  a  number  or 
algebraic  expression,  e.g.,  I  fe  Jl  2  J .  Result  =     or  0.5.  In  RPN  mode,  enter 
the  number  first,  then  use  the  key,  e.g.,  I  4  JUw^Jl    J .  Result  =  14  or  0.25. 

Addition,  subtraction,  multiplication,  division 

Use  the  proper  operation  key,  namely,  I  +  J  I  —  J  I  x  J  1.  -h  j .  In  ALG  mode, 
press  an  operand,  then  an  operator,  then  an  operand,  followed  by  an  Wm]  to 
obtain  a  result.  Examples: 

CX3GD3D  S  SDCIDCTD 
The  first  three  operations  above  are  shown  in  the  following  screen  shot: 


:3.7-H5.2 

S.9 

-2.2 

10.5 

In  RPN  mode,  enter  the  operands  one  after  the  other,  separated  by  an  [pfrm] , 
then  press  the  operator  key.  Examples: 

QJCZDCiJl^sl  CXDCZDCilD  CjD 

Alternatively,  in  RPN  mode,  you  can  separate  the  operands  with  a  space 
([    J )  before  pressing  the  operator  key.  Examples: 

C1DCIDCX3C1L3C1DCZDCID  Q 
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Using  parentheses 

Parentheses  can  be  used  to  group  operations,  as  well  as  to  enclose  arguments 
of  functions.  Tfie  parentfieses  are  available  through)  the  keystroke 

combination  l*i  }<J.  .  Parentheses  are  always  entered  in  pairs.  For 

example,  to  calculate  (5+3.2)/(7-2.2): 

In  ALG  mode: 

(33 1^  CXD  GD  CID  CD      ED  1^  CED  CH3  CID  GD  CID 

In  RPN  mode,  you  do  not  need  the  parenthesis,  calculation  is  done  directly  on 
the  stack: 

CS     CZD  a  CTD  CE]  ^     CID  QJ     Q  CiD 

In  RPN  mode,  typing  the  expression  between  quotes  will  allow  you  to  enter 

the  expression  like  in  algebraic  mode: 

CID  CS  3D  CZD  CTJ  CD  S 
SD 1^  CE)  CHD  CID  CD  CID  Cm3 

For  both,  ALG  and  RPN  modes,  using  the  Equation  Writer: 

^  CID  CiD  CD  CD  C2D  CD  S  CD  CHD  CID  CD  C2D 

The  expression  can  be  evaluated  within  the  Equation  writer,  by  using: 
^^^^ B™a  or,  CHD ^ EiEEIiS 

Absolute  value  function 

The  absolute  value  function,  ABS,  is  available  through  the  keystroke 
combination:  l*i  )abs    .   When  calculating  in  the  stack  in  ALG  mode,  enter 
the  function  before  the  argument,  e.g.,  I  *i  J^jjL_  I  *i-  Jl  2  JCDl  3  }C2llif™) 

In  RPN  mode,  enter  the  number  first,  then  the  function,  e.g., 

CD  CD  CD  CD  S3 
Squares  and  square  roots 

The  square  function,  SQ,  is  available  through  the  keystroke  combination: 

C^iJ^  •    When  calculating  in  the  stack  in  ALG  mode,  enter  the  function 

before  the  argument,  e.g.,  C5D^  C^DCDCDCDl^S) 
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In  RPN  mode,  enter  the  number  first,  then  the  function,  e.g., 

□D     QD     CSD  ?^ 
The  square  root  function,  V,  is  available  through  the  R  key.  When  calculating 
in  the  stack  in  ALG  mode,  enter  the  function  before  the  argument,  e.g., 

S     CTD  OD  C3D 

In  RPN  mode,  enter  the  number  first,  then  the  function,  e.g., 

CD  CX)  QD  CD  S 

Powers  and  roots 

The  power  function,     is  available  through  the  CD  key.   When  calculating 
in  the  stack  in  ALG  mode,  enter  the  base  (y)  followed  by  the  CD  key,  and 
then  the  exponent  (x),  e.g.,  CX3CDCDCDCDCDCDCTD 
In  RPN  mode,  enter  the  number  first,  then  the  function,  e.g., 

CD  CD  CD  CZD  QD  [X]  CD 

The  root  function,  XR001(y,x),  is  available  through  the  keystroke  combination 
[    J    ^  .  When  calculating  in  the  stack  in  ALG  mode,  enter  the  function 
XROOT  followed  by  the  arguments  (y,x),  separated  by  commas,  e.g., 

[jfj  57  LJJUD  L2JL7j(i?™) 

In  RPN  mode,  enter  the  argument  y,  first,  then,  x,  and  finally  the  function  call, 
e.g.,  CD  CD      CXI      CD  ^ 

Base-10  logarithms  and  powers  of  10 

Logarithms  of  base  1 0  are  calculated  by  the  keystroke  combination  CD— ^ 
(function  LOG)  while  its  inverse  function  (ALOG,  or  antilogarithm)  is  calculated 
by  using  L  *i  j'f'    .  In  ALG  mode,  the  function  is  entered  before  the  argument: 

CD -toe  CD  CD  CD  CD 

In  RPN  mode,  the  argument  is  entered  before  the  function 

CDCDCDCD(^  CD-^ 
CDCDCDra(^ 

Using  powers  of  10  in  entering  data 

Powers  of  ten,  i.e.,  numbers  of  the  form  -4.5x1 0'^,  etc.,  are  entered  by  using 
the  [iix]  key.    For  example,  in  ALG  mode: 

CDD  OJ  CD  CS     CDD  CTJ 
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Or,  in  RPN  mode: 

□J  Q  CS      C«D  CX]  S 
Natural  logarithms  and  exponential  function 

Natural  logarithms  (i.e.,  logarithms  of  base  e  =  2.71 8281 8282)  are 

calculated  by  the  keystroke  combination  LiiJ  ^  (function  LN)  while  its 

inverse  function,  the  exponential  function  (function  EXP)  is  calculated  by  using 
I  *n  Jgf  .  In  ALG  mode,  the  function  is  entered  before  the  argument: 

CZD  ^  CT]  CZD  C3D  CT] 

In  RPN  mode,  the  argument  is  entered  before  the  function 
Trigonometric  functions 

Three  trigonometric  functions  are  readily  available  in  the  keyboard:  sine 

([  SIN  J),  cosine  {i£2i)),  and  tangent  ([tan ]).  The  arguments  of  these  functions  are 
angles,  therefore,  they  can  be  entered  in  any  system  of  angular  measure 
(degrees,  radians,  grades).  For  example,  v/ith  the  DEG  option  selected,  v/e 
can  calculate  the  following  trigonometric  functions: 
In  ALG  mode: 

In  RPN  mode: 
Inverse  trigonometric  functions 

The  inverse  trigonometric  functions  available  in  the  keyboard  are  the  arcsine 
(ASIN),  arccosine  (ACOS),  and  arctangent  (ATAN),  available  through  the 
keystroke  combinations       ^sin  ^  I jn_l acqs  ^  and  ( Jn^l ^tan  ^  respectively. 
Since  the  inverse  trigonometric  functions  represent  angles,  the  answer  from 
these  functions  will  be  given  in  the  selected  angular  measure  (DEG,  RAD, 
GRD).  Some  examples  are  shown  next: 
In  ALG  mode: 

C5D  ^sw- CS  CZD  C2D  CX) 
C5D     CoD  GD  dD  C3D 
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(31)     CTD  CZ3  CX)  ex] 


In  RPN  mode: 

CX  CZD  CID  CX)  C5D 
CX  GD  CED  C3D  QD 

All  the  functions  described  above,  namely,  ABS,  SQ,  V,     XROOT,  LOG, 
ALOG,  LN,  EXP,  SIN,  COS,  TAN,  ASIN,  ACOS,  ATAN,  can  be  combined 
with  the  fundamental  operations  (L±JLziJL2<JL±J)  to  form  more  complex 
expressions.  The  Equation  Writer,  whose  operations  is  described  in  Chapter 
2,  is  ideal  for  building  such  expressions,  regardless  of  the  calculator 
operation  mode. 

Differences  between  functions  and  operators 

Functions  like  ABS,  SQ,  V,  LOG,  ALOG,  LN,  EXP,  SIN,  COS,  TAN,  ASIN, 
ACOS,  ATAN  require  a  single  argument.   Thus,  their  application  is  ALG 
mode  is  straightforward,  e.g.,  ABS(x).    Some  functions  like  XROOT  require 
two  arguments,  e.g.,  XROOT(x,y).   This  function  has  the  equivalent  keystroke 
sequence  I  r>  j^Z  . 

Operators,  on  the  other  hand,  are  placed  after  a  single  argument  or  between 
two  arguments.  The  factorial  operator  (I),  for  example,  is  placed  after  a 
number,  e.g.,  [  5  )[alpha)[  r»  J(.  2  J(flw^ .  Since  this  operator  requires  a  single 
argument  it  is  referred  to  as  a  unary  operator.  Operators  that  require  two 
arguments,  such  as  (.  +  J  [  —  J  I  x  J  [  -h  J  [  f  ],  are  binary  operators,  e.g.. 

Real  number  functions  in  the  MTH  menu 

The  MTH  (MaTHematics)  menu  include  a  number  of  mathematical  functions 
mostly  applicable  to  real  numbers.  To  access  the  MTH  menu,  use  the 
keystroke  combination  I  *i  )mth  .   With  the  default  setting  of  CHOOSE  boxes 
for  system  flag  1 1 7  (see  Chapter  2),  the  MTH  menu  is  shown  as  the  following 
menu  list; 
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HHTH  HEnU 

1. VECTOR..  1 

2.  HHTRIX.. 

3.  LIST.. 
H.HVPERROLIC. 
5.REHL.. 
e.EASE.. 

1    1  1 

ICHRCL 

OK 

HHTH  HERU 

G.BRSE.. 

?.PRORflRILITV.. 

S.FFT.. 

S.COHPLEK.. 

ID.CORSTflnTS.. 

ii.spEciRL  FuncTions..  1 

1         1         1  ICflnCL 

OH 

As  they  are  a  great  number  of  mathematic  functions  available  in  the  calculator, 
the  MTH  menu  is  sorted  by  the  type  of  object  the  functions  apply  on.  For 
example,  options  1 .  VECTOR..,  2.  MATRIX.,  and  3.  LIST.,  apply  to  those  data 
types  (i.e.,  vectors,  matrices,  and  lists)  and  will  discussed  in  more  detail  in 
subsequent  chapters.  Options  4.  HYPERBOLIC  and  5.  REAL.,  apply  to  real 
numbers  and  v/ill  be  discussed  in  detailed  herein.  Option  6.  BASE.,  is  used 
for  conversion  of  numbers  in  different  bases,  and  is  also  to  be  discussed  in  a 
separate  chapter.  Option  7.  PROBABILITY.,  is  used  for  probability 
applications  and  will  be  discussed  in  an  upcoming  chapter.   Option  8.  FFT.. 
(Fast  Fourier  Transform)  is  an  application  of  signal  processing  and  will  be 
discussed  in  a  different  chapter.   Option  9.  COMPLEX.,  contains  functions 
appropriate  for  complex  numbers,  which  will  be  discussed  in  the  next  chapter. 
Option  10.  CONSTANTS  provides  access  to  the  constants  in  the  calculator. 
This  option  will  be  presented  later  in  this  section.  Finally,  option  7  7.  SPECIAL 
FUNCTIONS.,  includes  functions  of  advanced  mathematics  that  will  be 
discussed  in  this  section  also. 


In  general,  to  apply  any  of  these  functions  you  need  to  be  aware  of  the 
number  and  order  of  the  arguments  required,  and  keep  in  mind  that,  in  ALG 
mode  you  should  select  first  the  function  and  then  enter  the  argument,  while  in 
RPN  mode,  you  should  enter  the  argument  in  the  stack  first,  and  then  select 
the  function. 


Using  calculator  menus: 

1 .  Since  the  operation  of  MTH  functions  (and  of  many  other  calculator 
menus)  is  very  similar,  we  will  describe  in  detail  the  use  of  the  4. 
HYPERBOLIC  menu  in  this  section,  with  the  intention  of  describing  the 
general  operation  of  calculator  menus.  Pay  close  attention  to  the  process 
for  selecting  different  options. 

2.  To  quickly  select  one  of  the  numbered  options  in  a  menu  list  (or  CHOOSE 
box),  simply  press  the  number  for  the  option  in  the  keyboard.  For 
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example,  to  select  option  4.  HYPERBOLIC  in  the  MTH  menu,  simply 
press  I  4  J . 

Hyperbolic  functions  and  their  inverses 

Selecting  Option  4.  HYPERBOLIC.  ,  in  the  MTH  menu,  and  pressing  lEull!, 
produces  the  hyperbolic  function  menu: 


HYPERBOLIC  HEnU 


2.  H£inH 

3.  COSH 
H.flCOSH 
S.TAnH 
e.ATAhH 


HYPERBOLIC  HEnU 

H.flCOJH 

S.TAnH 

CATARH 

?.EKPH 

g.LRPl 

1      1      1  IcfliiciT 

OH 

The  hyperbolic  functions  are: 

Hyperbolic  sine,  SINH,  and  its  inverse,  ASINH  or  sinh^ 
Hyperbolic  cosine,  COSH,  and  its  inverse,  ACOSH  or  cosh"^ 
Hyperbolic  tangent,  TANH,  and  its  inverse,  ATANH  or  tanh'^ 
This  menu  contains  also  the  functions: 

EXPM(x)  =  exp(x)-  1, 
LNPl(x)  =  ln{x+l). 
Finally,  option  9.  MATH,  returns  the  user  to  the  MTH  menu. 


For  example,  in  ALG  mode,  the  keystroke  sequence  to  calculate,  say, 
tanh(2.5),  is  the  follov/ing: 

Select  MTH  menu 
Select  the  4.  HYPERBOLIC,  menu 
Select  the  5.  TANH  function 
Evaluate  tanh(2.5) 


r  ^ — -I  iigi-n-inin 

L  4  J  iiilitgi 

dD  KI3B 


The  screen  shows  the  following  output: 


TflHH(2.5) 


,936614293151 


In  the  RPN  mode,  the  keystrokes  to  perform  this  calculation  are  the  following: 

m nn im Ifwaj  Enter  the  argument  in  the  stack 

CS*™-  Select  MTH  menu 

CTD  ills  Select  the  4.  HYPERBOLIC,  menu 

dD  IE3B  Select  the  5.  TAHH  function 
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The  result  is: 


,936614293151 


CH^CH  HELP 


The  operations  shown  above  assume  that  you  are  using  the  default  setting  for 
system  flag  1 1 7  (CHOOSE  boxes).  If  you  have  changed  the  setting  of  this  flag 
(see  Chapter  2)  to  SOFT  menu,  the  MTH  menu  will  show  as  labels  of  the  soft 
menu  keys,  as  follows  (left-hand  side  in  ALG  mode,  right  -hand  side  in  RPN 
mode): 


VECTRIMflTRKI  LIST  1  HVP  |  REAL  |  EASE 

Pressing  [nxt)  shows  the  remaining  options: 


PROE    FFT   CMPLK  COnST  SPECI 


PROE    FFT   CMPLK  COnST  SPECI 


Note:  Pressing  [jnj™^  will  return  to  the  first  set  of  MTH  options.  Also,  using 
the  combination  I  r»  J'^^r?  will  list  all  menu  functions  in  the  screen,  e.g. 


PROE 

FFT 

CMPLX 

CONST 

SPECIRL 

FUNCTIONS 

PROEI  FFT 

CMPLK|COnST|SPECI| 

Thus,  to  select,  for  example,  the  hyperbolic  functions  menu,  with  this  menu 
format  press  iHEiul! ,  to  produce: 


SIRH  lASIRHI  COSH  lACOSHI  TARH  lATARH 

Finally,  in  order  to  select,  for  example,  the  hyperbolic  tangent  (tanh)  function, 
simply  press  ISIIIIIll. 


Note:  To  see  additional  options  in  these  soft  menus,  press  the  [nxt]  key  or  the 
[  <-|  jpREv  keystroke  sequence. 
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For  example,  to  calculate  tanh(2.5),  in  the  ALG  mode,  when  using  SOFT 
menus  over  CHOOSE  boxes,  follow  this  procedure: 


[^MTH_  Select  MTH  menu 

fESiCI  Select  the  HYPERBOLIC,  menu 

iSSSS  Select  the  TANH  function 

CX)GDCID(^  Evaluate  tanh(2.5) 

In  RPN  mode,  the  same  value  is  calculated  using: 

I  2  Jl  •  jmifwaj  Enter  argument  in  the  stack 

[^MTH_  Select  A/IIH  menu 

mm  Select  the  HYPERBOLIC,  menu 

JKIiEl  Select  the  TANH  function 


As  an  exercise  of  applications  of  hyperbolic  functions,  verify  the  following 
values: 

SINH  (2.5)  =  6.05020..  ASINH(2.0)  =  1 .4436... 

COSH  (2.5)  =  6.13228..         ACOSH  (2.0)  =  1.3169... 
TANH(2.5)  =  0.98661 ..  ATANH(0.2)  =  0.2027... 

EXPM(2.0)  =  6.38905....         LNPl(l.O)  =  0.69314.... 

Once  again,  the  general  procedure  shown  in  this  section  can  be  applied  for 
selecting  options  in  any  calculator  menu. 


Real  number  functions 

Selecting  option  5.  REAL.,  in  the  MTH  menu,  with  system  flag  1 1 7  set  to 
CHOOSE  boxes,  generates  the  following  menu  list: 


REAL  HEAU 

^^^^^^^^^^^ 

H.HIA 

1       1       1  IcflncL 

OK 

REAL  HEAU 

?.AEJ  [ 

s.smn 

3.HAAT 

10.  XROA 

11.  IP 

12.  FP  II 

ICAACL 

OK 
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REAL  HEnU 

IH.TRnC 
15. FLOOR 
IE. CEIL 
1?.D-Hi 


I  III!  I  I     I    M         I         I         I         ICARCLl  OK 


Option  79.  MATH.,  returns  the  user  to  the  MTH  menu.  The  remaining 
functions  ore  grouped  into  six  different  groups  described  below. 

If  system  flag  1 1 7  is  set  to  SOFT  menus,  the  REAL  functions  menu  will  look  like 
this  (ALG  mode  used,  the  same  soft  menu  keys  will  be  available  in  RPN 
mode): 


■!MBiH!ltMi;Hai;[VW;HM 

KnrnwimaarmBimmEMUicm 

The  very  last  option,  IHuUI,  returns  the  user  to  the  MTH  menu. 
Percentage  functions 

These  functions  are  used  to  calculate  percentages  and  related  values  as 
follows: 

%  (y,x)     :  calculates  the  x  percentage  of  y 

%CH(y,x)  :  calculates  100(y-x)/x,  i.e.,  the  percentage  change,  the 
difference  between  two  numbers. 

%T(y,x)    :  calculates  100  x/y,  i.e.,  the  percentage  total,  the  portion 

that  one  number  (x)  is  of  another  (y). 
These  functions  require  two  arguments,   we  illustrate  the  calculation  of 
%T(1 5,45),  i.e.,  calculation  15%  of  45,  next.  We  assume  that  the  calculator 
is  set  to  ALG  mode,  and  that  system  flag  1 1 7  is  set  to  CHOOSE  boxes.  The 
procedure  is  as  follows: 


iJ^MTH_  Select  A/IT/-/ menu 

[  5  J  lilljlli  Select  the  5.  REAL.,  menu 

CX)  III3I  Select  the  5.  %T  function 

I  /  JL  5  J  Enter  first  argument 

CrfD  ;  Enter  a  comma  to  separate  arguments 

[  4  }[  5  ]  Enter  second  argument 


REftL  HERU 


IH 

TRRC 

15 

FLOOR 

IE 

CEIL 

17 

D-* 

IS 

R-* 
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[ENTER)  Calculate  function 

The  result  is  shown  next: 


::;T(15,45) 

300 

In  RPN  mode,  recall  that  argument  y  is  located  in  the  second  level  of  the  stack, 
while  argument  x  is  located  in  the  first  level  of  the  stack.  This  means,  you 
should  enter  x  first,  and  then,  y,  just  as  in  ALG  mode.  Thus,  the  calculation  of 
%T(15,45),  in  RPN  mode,  and  with  system  flag  1 1  7  set  to  CHOOSE  boxes, 
we  proceed  as  follows: 

[  I  }[  5  J(bv7h]  Enter  first  argument 

I  4  )l  5  ]lENTER}  Enter  second  argument 

(^MTH_  Select  MTH  menu 

C3D  hI3I  Select  the  5.  REAL,  menu 

QD  SiaS  Select  the  5.  %T  function 

Note:  The  exercises  in  this  section  illustrate  the  general  use  of  calculator 
functions  having  2  arguments.  The  operation  of  functions  having  3  or  more 
arguments  can  be  generalized  from  these  examples. 

As  an  exercise  for  percentage-related  functions,  verify  the  following  values: 
%(5,20)  =  7,  %CH(22,25)  =  13.6363..,  %T(500,20)  =  4 

Minimum  and  maximum 

Use  these  functions  to  determine  the  minimum  or  maximum  value  of  two 
arguments. 

MIN(x,y)  :  minimum  value  of  x  and  y 

MAX(x,y)  :  maximum  value  of  x  and  y 
As  an  exercise,  verify  that  MIN(-2,2)  =  -2,  MAX(-2,2)  =  2 

Modulo 

MOD:  y  mod  x  =  residual  of  y/x,  i.e.,  if  x  and  y  are  integer  numbers,  y/x  = 
d  +  r/x,  where  d  =  quotient,  r  =  residual.  In  this  case,  r  =  y  mod  x. 
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Please  notice  that  MOD  is  not  a  function,  but  rather  an  operator,  i.e.,  in  ALG 
mode,  MOD  should  be  used  as  y  MOD  x,  and  not  as  MuDOj?      .  Thus, 
the  operation  of  MOD  is  similar  to  that  of  L+J,  LszJ,  CXD,  C±D. 

As  an  exercise,  verify  that  15  MOD  4=15  mod  4  =  residual  of  15/4  =  3 

Absolute  value,  sign,  mantissa,  exponent,  integer  and  fractional  parts 

ABS(x)  :  calculates  the  absolute  value,  |x| 

SIGN(x):  determines  the  sign  of  x,  i.e.,  -1 ,  0,  or  1 . 

MANT(x):  determines  the  mantissa  of  a  number  based  on  logio- 

XPON(x):  determines  the  power  of  10  in  the  number 

IP(x)      :  determines  the  integer  part  of  a  real  number 

FP(x)      :  determines  the  fractional  part  of  a  real  number 

As  an  exercise,  verify  \ha\  ABS(-3)  =  j-3j  =3,  SIGN(-5)  =  -1,  MANT(2540)  = 

2.540,  XPON(2540)  =  3,  IP(2.35)  =  2,  FP(2.35)  =  0.35. 

Rounding,  truncating,  ffoor,  and  ce////?^  functions 

RND(x,y)    :  rounds  up  y  to  x  decimal  places 

TRNC(x,y)  :  truncate  y  to  x  decimal  places 

FLOOR(x)    :  closest  integer  that  is  less  than  or  equal  to  x 

CEIL(x)       :  closest  integer  that  is  greater  than  or  equal  to  x 

As  an  exercise,  verify  that  RND(1 .4567,2)  =  1.46,  TRNQl .4567,2)  =  1.45, 

FLOOR(2.3)  =  2,  CEIL(2,3)  =  3 

Radians-to-degrees  and  degrees-to-radians  functions 

D->R  (x)  :  converts  degrees  to  radians 

R^D  (x)  :  converts  radians  to  degrees. 

As  an  exercise,  verify  that  D^R(45)  =  0.78539  (i.e.,  45°  =  0.78539™=^), 
R^D(1.5)  =  85.943669..  (i.e.,  1 .5™<^  =  85.943669..°). 

Special  functions 

Option  1 1 .  Special  functions...  in  the  MTH  menu  includes  the  follov/ing 
functions: 
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SPECIAL 

FUnCTIOnS  HEAU 

a.psi 

3.Pfi 
H.HATH.. 

HELP  1  1 

1  ICAACLI 

OH 

GAMMA:         The  Gamma  function  r(a) 

PSI:  N-th  derivative  of  the  digommo  function 

Psi:  Digamma  function,  derivative  of  the  In(Gamma) 

The  Gamma  function  is  defined  by  r(a)  —     x"~^e~''dx .  This  function  has 

applications  in  applied  mathematics  for  science  and  engineering,  as  well  as 
in  probability  and  statistics. 


Factorial  of  a  number 

The  factorial  of  a  positive  integer  number  n  is  defined  as  n!=n-(n-l)-(n- 
2)  ...3-2  T ,  with  0/  =  7.  The  factorial  function  is  available  in  the  calculator  by 
using  jALPHA] (,    J L  2  J .  In  both  ALG  and  RPN  modes,  enter  the  number  first, 
followed  by  the  sequence  (diffS)[7^(;jJ .  Example:  Cni^w/ijCT^[  2  J(fWHl. 
The  Gamma  function,  defined  above,  has  the  property  that 

r(a)  =  (a-1)  r(a-l),  for  a  >  1 . 
Therefore,  it  can  be  related  to  the  factorial  of  a  number,  i.e.,  r(a)  =  (a-1}., 
when  a  is  a  positive  integer.  We  can  also  use  the  factorial  function  to 
calculate  the  Gamma  function,  and  vice  versa.  For  example,  r(5)  =  4!  or, 
[  4  JL/it/wJCrni  2  J(flw^.   The  factorial  function  is  available  in  the  MTH  menu, 
through  the  7.  PROBABILITY.,  menu. 


The  PSI  function,  ^(x,y),  represents  the  y-th  derivative  of  the  digamma  function, 

d" 

i.e.,  =  V^ix) ,  where  y^x)  is  known  as  the  digamma  function,  or 

dx" 

Psi  function.  For  this  function,  y  must  be  a  positive  integer. 

The  Psi  function,  y/(x),  or  digamma  function,  is  defined  as  y/{x)  =  ln[r(x)] . 
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Examples  of  these  special  functions  are  sfiown  here  using  both  the  ALG  and 
RPN  modes.   As  an  exercise,  verify  that  GAMMA(2.3)  =  1. 16671 1..., 
PSlil.5,3)  =  1.40909..,  and  Psi(l. 5)=  3.64899739..E-2. 


These  calculations  are  shown  in  the  following  screen  shot: 


GflMMR(2.3) 

1. 1667119052 

PSI(1.5,3) 

1.409091034 

Psi(1.5) 

3.64S997397S6E-2 


Calculator  constants 

The  following  are  the  mathematical  constants  used  by  your  calculator: 

•  e:         the  base  of  natural  logarithms. 

•  /:         the  imaginary  unit,  i'^  =  -1 . 

•  m         the  ratio  of  the  length  of  the  circle  to  its  diameter. 

•  MINR:  the  minimum  real  number  available  to  the  calculator. 

•  MAXR:  the  maximum  real  number  available  to  the  calculator. 

To  have  access  to  these  constants,  select  option  11.  CONSTANTS.,  in  the 
MTH  menu, 


HHTH  HEnU 

i.tmsz.. 

?.PROEflEILITV.. 

g.FFT.. 

S.COMPLEK.. 

iD.consTflnTS.. 

ii.spEciHL  FuncTion;..  I 

1       1       1  icflncL 

OK 

The  constants  are  listed  as  follows: 


H.  ((J.,1.) 

1       1       1  icflncL 

OK 

con^THnr^  hehu 

6.3.1H153265353 

7. Hint: 

g.l.E-HSS 

9  HAMR  1 

HWifUfT^^^^^^^^^^^BI 

1       1       1  icflncL 

OK 

Selecting  any  of  these  entries  will  place  the  value  selected,  whether  a  symbol 
(e.g.,  e,  /,  ;r,  MINR,  or  MAXR)  or  a  value  (2.71..,  (0, 1),  3. 14..,  lE-499, 
9.99. .E499)  in  the  stack. 
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Please  notice  that  e  is  available  from  the  keyboard  as  exp(l),  i.e., 
C5I]?^QI](^,  in  ALG  mode,  or  CT3(^  ED?^  ,  in  RPN  mode.  Also, 
Tt  is  available  directly  from  the  keyboard  as   •  Finally,  /  is  available 

by  using  (JnJ;  . 

Operations  with  units 

Numbers  in  the  calculator  can  have  units  associated  v^ith  them.  Thus,  it  is 
possible  to  calculate  results  involving  a  consistent  system  of  units  and  produce 
a  result  v/ith  the  appropriate  combination  of  units. 


The  UNITS  menu 

The  units  menu  is  launched  by  the  keystroke  combination  [  r»  J  units  (associated 
v/ith  the  (.  6  J  key).  With  system  flag  1 1 7  set  to  CHOOSE  boxes,  the  result  is 
the  following  menu: 


uniT£  HEnu 

2.L«n3th..  1 

3.flr<o.. 

H.V*lUH«.. 

5.TiH«.. 

i.Sftfl.. 

1       1       1  icfincL 

OK 

uniT£  HEnu 


7.Hltt.. 

s.rifis.. 
S.Ernraa.. 

10.  fiHsr.. 

11 .  ffiiiiri.. 


li.linifiritiiri.. 


UniT£  HEnu 


la.TsHpiraturs.. 
13.El<ctric  Curr<n't.. 
IH.AnjLt.. 
IS.Liaht.. 
Ifi.Rjjjj'ti^ri.. 


Option  ?.  Tools.,  contains  functions  used  to  operate  on  units  (discussed  later). 
Options  3.  Length.,  through  1 /.Viscosity.,  contain  menus  with  a  number  of 
units  for  each  of  the  quantities  described.  For  example,  selecting  option  8. 
Force.,  shows  the  following  units  menu: 


FORCE  HEnu 

i.n 

3.3f 

H.Rip 

5.  Ibf 

1      1      1  icHnoT 

OK 

FORCE  HEnu 

3.3F 

H.hip 

5.  IbF 

C  p  j  I  ^^^^^^^^ 

1       1       1  jcAnal 

OK 

The  user  will  recognize  most  of  these  units  (some,  e.g.,  dyne,  ore  not  used 
very  often  nowadays)  from  his  or  her  physics  classes:  N  =  newtons,  dyn  = 
dynes,  gf=  grams  -  force  (to  distinguish  from  gram-mass,  or  plainly  gram,  a 
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unit  of  mass),  kip  =  kilo-poundal  (1000  pounds),  Ibf  =  pound-force  (to 
distinguish  from  pound-moss),  pdl  =  poundol. 

To  attach  a  unit  object  to  a  number,  the  number  must  be  followed  by  an 
underscore.  Thus,  a  force  of  5  N  will  be  entered  as  5_N. 
For  extensive  operations  with  units  SOFT  menus  provide  a  more  convenient 
way  of  attaching  units.   Change  system  flag  1 1 7  to  SOFT  menus  (see 
Chapter  1 ),  and  use  the  keystroke  combination  CHUiwra  to  get  the  following 
menus.  Press  Ikxt)  to  move  to  the  next  menu  page. 


u  

TOOLS  LEnC   flREfl    VOL    TIME  SPEED 

MASS  FORCE  EHRG   POHR  PRESS  TEMP 

EI 

ELECT flncirrLIGHTT  RfiMVISC 


Pressing  on  the  appropriate  soft  menu  key  will  open  the  sub-menu  of  units  for 
that  particular  selection.  For  example,  for  the  SljOliEl  sub-menu,  the  following 
units  are  available: 


U  

1  H^s  \  iH^s  \  ft^i  \  Rph  1  Hph  1  hn^t 

■:    1  31  1         1         1  lUniTS 

Pressing  the  soft  menu  key  ijiiitKy  will  take  you  bock  to  the  UNITS  menu. 

Recall  that  you  con  always  list  the  full  menu  labels  in  the  screen  by  using 
I  r»        ,  e.g.,  for  the  IjIjjS  set  of  units  the  following  labels  will  be  listed: 


J 

ttierm 

erg 

lev 

Kcal 

eV 

cal 

Btu 

ft*lbf 

JHITS 

J     1  tri  \  Kr.ill.  \  r.iil.  1  RtU  |ft><Lb| 

■  th«rH|  H«V  \  iV   \         \  lUniTS 

Note:  Use  the  [nxtJ  key  or  the  I  *i  J^'^*'  keystroke  sequence  to  navigate 
through  the  menus. 


Available  units 

The  following  is  a  list  of  the  units  available  in  the  UNITS  menu.  The  unit 
symbol  is  shown  first  followed  by  the  unit  name  in  parentheses: 
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LENGTH 

m  (meter),  cm  (centimeter),  mm  (millimeter),  yd  (yard),  ft  (feet),  in  (inch),  Mpc 
(Mega  parsec),  pc  (parsec),  lyr  (light-year),  au  (astronomical  unit),  km 
(kilometer),  mi  (international  mile),  nmi  (nautical  mile),  miUS  (US  statute  mile), 
chain  (chain),  rd  (rod),  fath  (fathom),  ftUS  (survey  foot).  Mil  (Mil),  \i  (micron), 
A  (Angstrom),  fermi  (fermi) 

AREA 

m^2  (square  meter),  cm'^2  (square  centimeter),  b  (barn),  yd'^2  (square  yard), 
ft'^2  (square  feet),  in'^2  (square  inch),  km'^2  (square  kilometer),  ha  (hectare), 
a  (are),  mi'^2  (square  mile),  miUS'^2  (square  statute  mile),  acre  (acre) 

VOLUME 

m'^3  (cubic  meter),  st  (stere),  cm'^S  (cubic  centimeter),  yd'^3  (cubic  yard),  ff'S 
(cubic  feet),  in'^S  (cubic  inch),  I  (liter),  galUK  (UK  gallon),  galC  (Canadian 
gallon),  gal  (US  gallon),  qt  (quart),  pt  (pint),  ml  (mililiter),  cu  (US  cup),  ozfl  (US 
fluid  ounce),  ozUK  (UK  fluid  ounce),  tbsp  (tablespoon),  tsp  (teaspoon),  bbl 
(barrel),  bu  (bushel),  pk  (peck),  fbm  (board  foot) 

TIME 

yr  (year),  d  (day),  h  (hour),  min  (minute),  s  (second),  Hz  (hertz) 
SPEED 

m/s  (meter  per  second),  cm/s  (centimeter  per  second),  ft/s  (feet  per  second), 
kph  (kilometer  per  hour),  mph  (mile  per  hour),  knot  (nautical  miles  per  hour),  c 
(speed  of  light),  ga  (acceleration  of  gravity  ) 

MASS 

kg  (kilogram),  g  (gram).  Lb  (avoirdupois  pound),  oz  (ounce),  slug  (slug),  Ibt 
(Troy  pound),  ton  (short  ton),  tonUK  (long  ton),  t  (metric  ton),  ozt  (Troy  ounce), 
ct  (carat),  grain  (grain),  u  (unified  atomic  mass),  mol  (mole) 

FORCE 

N  (nev/ton),  dyn  (dyne),  gf  (gram-force),  kip  (kilopound-force),  Ibf  (pound- 
force),  pdl  (poundal) 
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ENERGY 

J  (joule),  erg  (erg),  Kcal  (kilocalorie),  Cal  (calorie),  Btu  (International  table  btu), 
ftxibf  (foot-pound),  therm  (EEC  therm),  MeV  (mega  electron-volt),  eV  (electron- 
volt) 

POWER 

W  (watt),  hp  (horse  pov/er), 
PRESSURE 

Pa  (pascal),  atm  (atmosphere),  bar  (bar),  psi  (pounds  per  square  inch),  torr 
(torr),  mmHg  (millimeters  of  mercury),  InHg  (inches  of  mercury),  inH20  (inches 
of  v/ater), 

TEMPERATURE 

°C  (degree  Celsius),  °F  (degree  Fahrenheit),  K  (Kelvin),  °R  (degree  Rankine), 
ELECTRIC  CURRENT  (Electric  measurements) 

V  (volt),  A  (ampere),  C  (coulomb),  Q  (ohm),  F  (farad),  W  (watt),  Fdy  (faraday), 
H  (henry),  mho  (mho),  S  (siemens),  T  (tesia),  Wb  (weber ) 

ANGLE  (planar  and  solid  angle  measurements) 

°  (sexagesimal  degree),  r  (radian),  grad  (grade),  arcmin  (minute  of  arc),  arcs 
(second  of  arc),  sr  (steradian) 

LIGHT  (Illumination  measurements) 

fc  (footcandle),  flam  (footlambert),  Ix  (lux),  ph  (phot),  sb  (stilb),  Im  (lumem),  cd 
(candela),  lam  (lambert) 

RADIATION 

Gy  (gray),  rod  (rod),  rem  (rem),  Sv  (sievert),  Bq  (becquerel),  Ci  (curie),  R 
(roentgen) 

VISCOSITY 

P  (poise),  St  (stokes) 
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Units  not  listed 

Units  not  listed  in  the  Units  menu,  but  available  in  the  calculator  include:  gmol 
(gram-mole),  Ibmol  (pound-mole),  rpm  (revolutions  per  minute),  dB  (decibels). 
These  units  are  accessible  through  menu  1 1  7.02,  triggered  by  using 
MENU(1  1 7.02)  in  ALG  mode,  or  1 1  7.02        MENU  in  RPN  mode.  The 
menu  will  show  in  the  screen  as  follows  (use  I  r>  J'<T?to  show  labels  in 
display): 


gmol 
Ibmol 

rpm 
dE 

EQLIB 


These  units  are  also  accessible  through  the  catalog,  for  example: 

gmol:  (.    J_cg  (^lpha}{P^(5] 

Ibmol:  CEI]_«z;  (^^I3D(3 

rpm:  I  r»  J_cg  [alpha)1  <n  ](r} 

dB:  [^_cM,{^^Uj(D\ 

Converting  to  base  units 

To  convert  any  of  these  units  to  the  default  units  in  the  SI  system,  use  the 
function  UBASE.  For  example,  to  find  out  what  is  the  value  of  /  poise  (unit  of 
viscosity)  in  the  SI  units,  use  the  following: 


In  ALG  mode,  system  flag  1 1 7  set  to  CHOOSE  boxes: 


wjrma 


[      J  UNITS 


Select  the  UNITS  menu 
Select  the  TOOLS  menu 
Select  the  UBASE  function 
Enter  1  and  underline 
Select  the  UNITS  menu 
Select  the  VISCOSITY  option 
Select  the  UNITS  menu 
Convert  the  units 


Page  3-21 


This  results  in  the  following  screen  (i.e.,  7  poise  =  0.  ?  kg/(m-s)): 


UEflSE(M_P5 


\f\-5 


In  RPN  mode,  system  flog  1 1 7  set  to  CHOOSE  boxes: 


Enter  1  (no  underline) 

(~p>^  UNITS 

Select  the 

UNITS  menu 

;»i":r!-9]ii 

 iiai 

Select  the 

VISCOSITY  option 

Select  the 

unit  P  (poise) 

(~r»3  IMTS 

Select  the 

UNITS  menu 

Select  the 

TOOLS  menu 

(  ^  Bmnn 

\J/  miASM 

Select  the 

UBASE  function 

In  ALG  mode,  system  flog  1 1 7  set  to  SOFT  menus: 


(7r»^  UMTS 

CD 

[      J  UNITS 


Select  the  UNITS  menu 
Select  the  TOOLS  menu 
Select  the  UBASE  function 
Enter  1  and  underline 
Select  the  UNITS  menu 
Select  the  VISCOSITY  option 
Select  the  unit  P  (poise) 
Convert  the  units 


In  RPN  mode,  system  flog  1 1 7  set  to  SOFT  menus: 


(j^l  UNITS 


Enter  1  (no  underline) 
Select  the  UNITS  menu 
Select  the  VISCOSITY  option 
Select  the  unit  P  (poise) 
Select  the  UNITS  menu 
Select  the  TOOLS  menu 
Select  the  UBASE  function 


Attaching  units  to  numbers 

To  attach  a  unit  object  to  a  number,  the  number  must  be  followed  by  an 
underscore  ([    J  - ,  l<ey(8,5)).  Thus,  a  force  of  5  N  will  be  entered  as  5_N. 
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Here  is  the  sequence  of  steps  to  enter  this  number  in  ALG  mode,  system  flog 
1 1 7  set  to  CHOOSE  boxes: 

LSJUiJ  =;  Enter  number  and  underscore 

(]f)_ms  Access  the  UNITS  menu 

dDESi  Select  units  of  force  (8.  Force..) 

Select  Newtons  (N) 
Enter  quantity  with  units  in  the  stack 


The  screen  will  look  like  the 


ollowing: 


5_H 

Note:  If  you  forget  the  underscore,  the  result  is  the  expression  5*N,  where  N 
here  represents  a  possible  variable  name  and  not  Newtons. 


To  enter  this  same  quantity,  with  the  calculator  in  RPN  mode,  use  the  following 
keystrokes: 

L  5  J  Enter  number  (do  not  enter  underscore) 

CB-^M?  Access  the  UNITS  menu 

CZDIIhSI  Select  units  of  force  (8.  Force..) 

ma  Select  Newtons  (N) 

Notice  that  the  underscore  is  entered  automatically  when  the  RPN  mode  is 
active.  The  result  is  the  following  screen:  

^'[■■■■riihl  llTil  1 1  [^■■■i 

As  indicated  earlier,  if  system  flag  1  1  7  is  set  to  SOFT  menus,  then  the  UNITS 
menu  will  show  up  as  labels  for  the  soft  menu  keys.  This  set  up  is  very 
convenient  for  extensive  operations  with  units. 

The  keystroke  sequences  to  enter  units  when  the  SOFT  menu  option  is  selected, 
in  both  ALG  and  RPN  modes,  are  illustrated  next.  For  example,  in  ALG  mode, 
to  enter  the  quantity  5_N  use: 

[5  J(.    J  Enter  number  and  underscore 
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5!!"!^'E~'E'^!"I 


(nxT) 

USES 

(SVTiERl 


Access  the  UNITS  menu 

Select  units  of  force 

Select  Newtons  (N) 

Enter  quantity  with  units  in  the  stack 


The  same  quantity,  entered  in  RPN  mode  uses  the  following  keystrokes: 
I  5  J  Enter  number  (no  underscore) 

(^jms  Access  the  UNITS  menu 

(nxt)  ansSi  Select  units  of  force 

USES  Select  Newtons  (N) 


Note:  You  can  enter  a  quantity  with  units  by  typing  the  underline  and  units 
with  the  (AiMj keyboard,  e.g.,   -(^m}(N]  will  produce  the  entry:  5._M 


Unit  prefixes 

You  can  enter  prefixes  for  units  according  to  the  following  table  of  prefixes 

from  the  SI  system. 

The  prefix  abbreviation  is  shown  first,  followed  by  its  name,  and  by  the 
exponent  x  in  the  factor  10"  corresponding  to  each  prefix: 


Prefix 

Name 

X 

Prefix 

Name 

X 

Y 

yotta 

+24 

d 

deci 

-1 

Z 

zetta 

+21 

c 

centi 

-2 

E 

exa 

+  18 

m 

milli 

-3 

P 

peta 

+15 

micro 

-6 

T 

tera 

+12 

n 

nano 

-9 

G 

giga 

+9 

P 

pico 

-12 

M 

mega 

+6 

f 

femto 

-15 

k,K 

kilo 

+3 

a 

atto 

-18 

h,H 

hecto 

+2 

z 

zepto 

-21 

D(*) 

deka 

+1 

y 

yocto 

-24 

(*)  In  the  SI  system,  this  prefix  is  olo  rather  than  D.  Use  D  for  deka  in  the 
calculator,  however. 


Page  3-24 


To  enter  these  prefixes,  simply  type  the  prefix  using  the  [alpha]  keyboard.  For 
example,  to  enter  123  pm  (1  picometer),  use: 

CID  CXD  CX)  C3  ^  (d^)  CSD  (3  (d^l  QD  (SI 

Using  DBASE  to  convert  to  the  default  unit  (1  m)  results  in: 


ISS'l.pm 

123_pm 

UEflSEtflHSd)) 

.  000000000 1£3_[V1 


COnVE  UEA^E  UVAL  UFACT KJniT  UniT£ 


Operations  with  units 

Once  a  quantity  accompanied  with  units  is  entered  into  the  stack,  it  can  be 
used  in  operations  similar  to  plain  numbers,  except  that  quantities  with  units 
cannot  be  used  as  arguments  of  functions  (say,  SQ  or  SIN).  Thus,  attempting 
to  calculate  LN(10_m)  will  produce  an  error  message:  Error:  Bad  Argument 
Type. 

Here  are  some  calculation  examples  using  the  ALG  operating  mode.  Be 
warned  that,  when  multiplying  or  dividing  quantities  with  units,  you  must 

enclosed  each  quantity  with  its  units  between  parentheses.  Thus,  to  enter,  for 
example,  the  product  1  2.5m  x  5.2_yd,  type  it  to  read  (1  2.5_m)*(5.2_yd) 


l£.5_[vi'5.£_yd 


COnVE  UEflSE  UVflL  UFflCT  -KiniT  UniTS 


which  shows  as  65_(m-yd).  To  convert  to  units  of  the  SI  system,  use  function 
UBASE: 


l£.5_[vi'5.£_yd 

UERSEtRHSd)) 


2 


59.436_m 


COnVE  UEflSE  UVflL  UFflCT  -KiniT  UniTS 


Note:  Recall  that  the  ANS(1 )  variable  is  available  through  the  keystroke 
combination  [  <n  J ^'^^   (associated  with  the  I^nter]  key). 
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To  calculate  a  division,  say,  3250  mi  /  50  h,  enter  it  as 
(3250_mi)/(50_h)  («™] : 


.  3250.1_mi 

which  transformed  to  Si  units,  with  function  DBASE,  produces: 

:UERSE(RHS(1)) 


COnVElUEA^El  UVHL  |UFHCT|-KiniT|UniT£ 


Addition  and  subtraction  can  be  performed,  in  ALG  mode,  without  using 
parentheses,  e.g.,  5  m  +  3200  mm,  can  be  entered  simply  as  5_m  + 
3200_mm  (^: 

:UEflSE(flHS(l)) 

:5'l_m+3200'l_mm 
 S2S0.-[nm 

More  complicated  expression  require  the  use  of  parentheses,  e.g., 
(12_mm)*(l_cm'^2)/(2_s)(^h  


.  12.1_mm.M 

2 

2-l.s 

2 

* 

^-  s 

1  yd^-a  1  ft'-a  1  in'-a 

Stack  calculations  in  the  RPN  mode,  do  not  require  you  to  enclose  the 
different  terms  in  parentheses,  e.g., 

1  2_m  [ENTER]  1 .5_yd  [enter}  I  X  J 
3250_mi        50_h  CTJ 

These  operations  produce  the  following  output: 
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Also,  try  the  following  operations: 

5_m  [fNTER]  3200_mm  (mm)  L+J 
1  2_mm  (^ra)  l_cm'^2  lENm][j<j  2  s  [b™] 

These  last  two  operations  produce  the  following  output: 


3: 

2: 
l: 

S200._mm 

2 

Note:  Units  are  not  allowed  in  expressions  entered  in  the  equation  writer. 


Units  manipulation  tools 

The  UNITS  menu  contains  a  TOOLS  sub-menu,  which  provides  the  following 
functions: 

CONVERT(x,y):  convert  unit  object  x  to  units  of  object  y 
UBASE(x):         convert  unit  object  x  to  SI  units 
UVAL(x):  extract  the  value  from  unit  object  x 

UFACT(x,y):      factors  a  unit  y  from  unit  object  x 
^UNIT(x,y):      combines  value  of  x  with  units  of  y 

The  UBASE  function  was  discussed  in  detail  in  an  earlier  section  in  this 
chapter.  To  access  any  of  these  functions  follow  the  examples  provided 
earlier  for  UBASE.  Notice  that,  while  function  UVAL  requires  only  one 
argument,  functions  CONVERT,  UFACT,  and  ^UNIT  require  two  arguments. 

Try  the  following  exercises,  in  your  favorite  calculator  settings.  The  output 
shown  below  was  developed  in  ALG  mode  with  system  flat  1  1  7  set  to  SOFT 
menu: 


Examples  of  CONVERT 
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These  examples  produce  the  same  result,  i.e.,  to  convert  33  watts  to  btu's 

CONVERT(33_W,  1  _hp) 
CONVERT(33_W,l  l_hp)  ^ 

These  operations  are  shown  in  the  screen  as: 


Examples  of  UVAL: 


C0HVERTt33.1_N,M_hp) 

4. 425372S9566E-£_hip 
C0HVERTt33. 1  ■  1  _W .  1 1  ■  1  ■  1 
4.425372S9566E-2_hip 


UVAL(25_ft/s)  («™} 
UVAL(0.021_cm^3)(^ 


:UVflL[254_ 

^1 

£5. 

:UVRl(.021 

_cm  J 

.021 

H  I  CH'S  I  yd'-J  I         I  in'S 


Examples  of  UFACT 


UFACT(l_ha,18_km'^2)  ^ 
UFACT(1_mm,15.1_cm) 


UFRCT 


(M_hia, 


IS'l.km 


.01_km 
UFRCT(M_mm,15'l-cm) 

.  l_cm 


Examples  of  ^UNIT 


^UNIT(25,l_m)(^ 
^UNiT(11.3,1_mph)(ws 


■^UHIT(25,M_m) 


25_[vi 


■*UHIT(11.3,12.M_mphi) 

1 1 . 3_[viphi 


COnVE  UEA^E  UVAL  UFACT KJniT  UniT£ 
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Physical  constants  in  the  calculator 

Following  along  the  treatment  of  units,  we  discuss  the  use  of  physical 
constants  that  are  available  in  the  calculator's  memory.  These  physical 
constants  are  contained  in  a  constants  //brar/ activated  with  the  command 
CONLIB.   To  launch  this  command  you  could  simply  type  it  in  the  stack: 

(alpha)  (alpha}  (c]  (o\(n\(l\(T\  (8]  (alpha)  (enter) 

or,  you  can  select  the  command  CONLIB  from  the  command  catalog,  as 
follows:  First,  launch  the  catalog  by  using:  (jfJ_cAJ  [alpha)(c]  .  Next,  use  the  up 
and  down  arrow  keys  <^'^  to  select  CONLIB.  Finally,  press  the  CZD  (BLS) 
soft  menu  key.  Press  (inter) ,  if  needed. 


The  constants  library  screen  will  look  like  the  following  (use  the  down  arrow 
key  to  navigate  through  the  library): 


HR:  Ryogadro  s  number 


^^^consTflnrs  lierary^^^    ^^^consTflnrs  lirrhrv 

(j:  Stef  an-Eoltzmann 
c:  speed  of  1  igtit 
60:  permittivity 
'  permeab  i 1 i  t  y 
ccel  of  gray  it*-! 


k:  Eoltzmann 
Vm:  molar  volume 
R:  universal  gas 
StdT:  std  temperature 
StdP:  std  pressure  J 


SI  ■!  ERGL  |UniT"|VflLUE| -tSTK  I  4UIT 


COnSTflRTS  LIERflRV^^^ 

hi:  Planck's 

hibar:  Dirac's 

q:  electronic  chiarge 

me:  electron  mass 


at  io 


Z\  ■  ERGL  UniTi  VALUE  -^TK  CUIT 


CORSTflRTS  LIERRRV^^^ 

iaE:  Eohir  magneton  1 

\yW''  nuclear  magneton 

^^0:  phioton  wayelengthi 

f0:  phioton  frequency 

l\c:  Compton  wauelen 


rad:   1  radian 


Z\  ■  ERGL  UniTi  VALUE  -(STK  KUIT 


ray  it at  ion 


SI  ■!  ERGL  |URIT"|VflLUE| -tSTK  I  4UIT 


^^^^CVRSTARTS  LIERARY^^ 

mpme:  mp^^me  ratio 
«:  fine  structure 
0:  mag  flux  quantum 
F:  Faraday 
Rto:  Rudberg 


a0:  Eohir  radius 


SI  ■  ERGL  URITi  VALUE  -(STK  CUIT 


CVRSTARTS  LIERARV^^^ 

twoir:  2ir  radians 
angl:  £  in  trig  mode 
c3:  Nien's 

kq:  k^^. 


SI  ■  ERGL  URITi  VALUE  -(STK  CUIT 


^^^CVRSTARTS  LIERARV^^^ 
kq:    k.^q  t 


eoq 
qeB 
esi 


6  0/q 
■11*6  0 

dielectric  const 


SI  ■  ERGL  UniT"  VALUE  -^TK  4UIT 
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The  soft  menu  keys  corresponding  to  this  CONSTANTS  LIBRARY  screen 

include  the  following  functions: 

SI         when  selected,  constants  values  are  shown  in  SI  units 
ENGL    when  selected,  constants  values  are  shown  in  English  units  ( 
UNIT    when  selected,  constants  are  shown  with  units  attached  (*) 
VALUE  when  selected,  constants  are  shown  without  units 
^STK   copies  value  (with  or  without  units)  to  the  stack 
QUIT    exit  constants  library 

(*)  Active  only  if  the  function  VALUE  is  active. 


This  is  the  way  the  top  of  the  CONSTANTS  LIBRARY  screen  looks  when  the 
option  VALUE  is  selected  (units  in  the  SI  system): 


lCOnSTflnTSLI|RflRVS 

Vm:  22.4141_1.^9mol 
R:  S.31451_J/t9mol*K> 
StdT:  273.15_K 
StdP:   101.325_kPa  U 


To  see  the  values  of  the  constants  in  the  English  (or  Imperial)  system,  press  the 
iMSs  option: 


0063E-27_Etu/.. 
Vm:  359.0394_ft-^3/lb.. 
R:  10.73164_psi*ft-^3.. 
StdT:  491.67_°R 
StdP:  14.6959_psi 


SI    EnCL"  UniT"  VfiLU"  -^TK  4UIT 


If  we  de-select  the  UNITS  option  (press  IHIilLiliiifii )  only  the  values  are  shown 
(English  units  selected  in  this  case): 


consTflnrs  lierhrv 


HR:  6.0221367E23 


k:  7.270063E-27 
Vm:  359.0394 
R:  10.73164 
StdT:  491.67 
StdP:  14.6959 


SI    EHGL"  UniTS  VfiLU"  -^TK  4UIT 
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To  copy  the  value  of  Vm  to  the  stack,  select  the  variable  name,  and 

press  lEiialli,  then,  press  lEilEiEiB.  For  the  calculator  set  to  the  ALG,  the  screen 

v/ill  look  like  this: 


iCOHLIB 

Vm: 359. 0394 

CHICHI  HELP  1         1         1  1 

The  display  shows  what  is  called  a  fagged  value,  Vni"  3-i'3. 13394.  In  here, 
Vm,  is  the  tag  of  this  result.  Any  arithmetic  operation  with  this  number  will 

ignore  the  tag.  Try,  for  example:  L  r>  J  ln [  j  JCxll.  <n  ]Mis_  \mm] ^  which 

produces: 


iCOHLIB 

Vm: 359. 0394 

:LH(2flHS(l)) 

  6. 

57657931233 

CflSCMIHELPI         1         1  1 

The  same  operation  in  RPN  mode  will  require  the  following  keystrokes  (after 
the  value  of  Vm  was  extracted  from  the  constants  library):  I  2  Jlfw«J(.  x  JL  J 

 IN 

Special  physical  functions 

Menu  1  1  7,  triggered  by  using  MENU(1 1 7)  in  ALG  mode,  or  1 1 7  MENU 
in  RPN  mode,  produces  the  following  menu  (labels  listed  in  the  display  by 
using  CED^): 

ZFHCTDR  I 

FRHHIHG 

DRRCY 

F0^. 

BIDEHS 
TDELTR 


ZFHCT|FHnni|DARCY|  FDh  |£IDEn|TDELT 


The  functions  include: 

ZFACTOR:  gas  compressibility  Z  factor  function 
FANNING:  Fanning  friction  factor  for  fluid  flow 
DARCY:  Darcy-Weisbach  friction  factor  for  fluid  flow 
FOX:  Black  body  emissive  power  function 
SIDENS:  Silicon  intrinsic  density 
TDELTA:  Temperature  delta  function 
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In  the  second  page  of  this  menu  (press  [hxt])  we  find  the  following  items: 


In  this  menu  page,  there  is  one  function  (TINC)  and  a  number  of  units 
described  in  an  earlier  section  on  units  (see  above).  The  function  of  interest  is: 

TINC:    temperature  increment  command 

Out  of  all  the  functions  available  in  this  MENU  (UTILITY  menu),  namely, 
ZFACTOR,  FANNING,  DARCY,  FOX,  SIDENS,  TDELTA,  and  TINC,  functions 
FANNING  and  DARCY  are  described  in  Chapter  6  in  the  context  of  solving 
equations  for  pipeline  flov/.  The  remaining  functions  are  described  following. 


Function  ZFACTOR  calculates  the  gas  compressibility  correction  factor  for 
nonideal  behavior  of  hydrocarbon  gas.  The  function  is  called  by  using 
ZFACTOR(xj,  yp),  where  Xj  is  the  reduced  temperature,  i.e.,  the  ratio  of  actual 
temperature  to  pseudo-critical  temperature,  and  yp  is  the  reduced  pressure,  i.e., 
the  ratio  of  the  actual  pressure  to  the  pseudo-critical  pressure.    The  value  of  Xj 
must  be  between  1 .05  and  3.0,  while  the  value  of  yp  must  be  between  0  and 
30.    Example,  in  ALG  mode: 


Function  fOX 

Function  FOX  (T,  X)  calculates  the  fraction  (dimensionless)  of  total  black-body 
emissive  power  at  temperature  T  between  wavelengths  0  and  X.  If  no  units 
are  attached  to  T  and  X,  it  is  implied  that  T  is  in  K  and  X  in  m.  Example,  in 
ALG  mode: 


Function  ZFACTOR 


:ZFflCT0Rt2.5.12.5) 

1 . 259S076239S 


:F0^.(452.,.  00001) 

.567343723392 
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Function  SIDENS 

Function  SIDENS(T)  calculates  the  intrinsic  density  of  silicon  (in  units  of  1/cm'^) 
OS  a  function  of  temperature  T  (T  in  K),  for  T  between  0  and  1 685  K.  For 
example, 

:SIDEHS(450.) 

6.0799561S23SE13 


ZFHCT|FHnni|DARCY|  TOi.  |£IDEn|TDELT 


Function  TDELTA 

Function  TDELTA(To,T()  yields  the  temperature  increment  T(  -  Tq.  The  result  is 
returned  with  the  same  units  as  Tq,  if  any.  Otherwise,  it  returns  simply  the 
difference  in  numbers.  For  example. 


:TDELTfl(25_°F,52_°C) 

-100.6_""F 


ZFACT|FAnni|DARCY|  TOi.  |£IDEn|TDELT 


The  purpose  of  this  function  is  to  facilitate  the  calculation  of  temperature 
differences  given  temperatures  in  different  units.  Otherwise,  it's  simply 
calculates  a  subtraction,  e.g.,  


:TDELTR(250.,520.) 

-270. 


ZFACT|FAnni|DARCY|  TOi.  |£IDEn|TDELT 


Function  TINC 

Function  TINC(Tq,AT)  calculates  Tq+DT.  The  operation  of  this  function  is  similar 
to  that  of  function  TDELTA  in  the  sense  that  it  returns  a  result  in  the  units  of  Tg. 
Otherwise,  it  returns  a  simple  addition  of  values,  e.g., 


TIHC(125_""F,-25_K) 
TIHC(256.,25.) 

2S1, 
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Defining  and  using  functions 

Users  can  define  their  own  functions  by  using  tfie  DEF  command  available 
thioughit  thie  keystroke  sequence  C2D?^  (associated  witfi  tfie  [  2  J  key).  Tfie 
function  must  be  entered  in  tfie  following  format: 

Function_name(arguments)  =  expression_containing_arguments 

For  example,  we  could  define  a  simple  functionHfxj  =  ln(x+l)  +  exp(-x). 
Suppose  that  you  have  a  need  to  evaluate  this  function  for  a  number  of 
discrete  values  and,  therefore,  you  wont  to  be  able  to  press  a  single  button 
and  get  the  result  you  want  without  having  to  type  the  expression  in  the  right- 
hand  side  for  each  separate  value.  In  the  following  example,  we  assume  you 
have  set  your  calculator  to  ALG  mode.  Enter  the  following  sequence  of 
keystrokes: 

(3D      CD(Z^^  (3 13D 1^  (d^l  ED  (3  CD  CE3  ^ 
The  screen  will  look  like  this: 


:  DEF  I  He('h(x)=LH(x+  1  )+e^') 
HOVRL 


+^KIP|SKIP-H  H)EL  I  DEL-f|DEL  L|  inS  ■ 


Press  the  I  var  J  key,  and  you  will  notice  that  there  is  a  new  variable  in  your  soft 
menu  key  (HCl!].  To  see  the  contents  of  this  variable  press  L  J 83113.  The  screen 
will  show  now: 

:  DEF  I  He('h(x)=LH(x+  1  )+e^') 
HOVRL 

*:  +  X  'LHtx+l>+EXPtx> ' 
■!MI31iaii^.lilB4MM«i;MM 

Thus,  the  variable  H  contains  a  program  defined  by: 
«^x'LN(x+l)  +  EXP(x)'  » 


This  is  a  simple  program  in  the  default  programming  language  of  the  HP  48 
G  series,  and  also  incorporated  in  the  HP  49  G  series.   This  programming 
language  is  called  UserRPL.   The  program  shown  above  is  relatively  simple 
and  consists  of  two  parts,  contained  between  the  program  containers  \  \  >  >  : 
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•  Input:  ^  X  y. 

•  Process:  'LN(x+l )  +  EXP(x)  ' 

This  is  to  be  interpreted  as  saying:  enter  a  value  that  is  temporarily  assigned 
to  the  name  x  (referred  to  as  a  local  variable),  evaluate  the  expression 
between  quotes  that  contain  that  local  variable,  and  shov^  the  evaluated 
expression. 

To  activate  the  function  in  ALG  mode,  type  the  name  of  the  function  follov/ed 

by  the  argument  between  parentheses,  e.g.,  iBwi  1*1 } 'J.  L  2  JlwraJ .  Some 

examples  are  shown  below: 


:H(2) 

:H(1.2) 

4. 10S5742S31 

H  IPPHR 

2 

H  IPF-HRIECHni 

In  the  RPN  mode,  to  activate  the  function  enter  the  argument  first,  then  press 

the  soft  menu  key  corresponding  to  the  variable  name  illi!!]llill.  For  example, 
you  could  try:  t_2jtff™ji|T||i  .  The  other  examples  shown  above  can  be 


entered  by  using:  CZDCZDCiJ^^" 


Functions  can  have  more  than  2  arguments.  For  example,  the  screen  below 
shows  the  definition  of  the  function  K{a,P)  =  a+ji,  and  its  evaluation  with  the 
arguments  K(^,k),  and  K(l  .2,2.3):  


DEFIHE('K(o:,p)=o:+P') 
K(J2,tt) 


HOVRL 

■J2+TI 

3.5 

The  contents  of  the  variable  K  are:  «  ^  a  (3  'a+p'  » 


Functions  defined  by  more  than  one  expression 

In  this  section  we  discuss  the  treatment  of  functions  that  are  defined  by  two  or 
more  expressions.  An  example  of  such  functions  would  be 
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The  calculator  provides  the  function  IFTE  (IF-Then-Else)  to  describe  such 
functions. 


The  IFTE  function 

The  IFTE  function  is  written  as  \fJE{condifion,  operationjfjrue,  operation_if_false) 
If  condition  is  true  then  operation_if_true  is  performed,  else  operation_if_false 
is  performed.  For  example,  we  con  write  'f(x)  =  IFTE(x>0,  x'^2-1,  2*x-l)',  to 
describe  the  function  listed  above.  Function  IFTE  is  accessible  from  the 
function  catalog  ((j^l  cat  ).  The  symbol  '>'  (greater  than)  is  available  as 
(associated  with  the  LfcJ  key).  To  define  this  function  in  ALG  mode  use  the 
command:  DEF(f(x)  =  IFTE(x>0,  x'^2-1 ,  2*x-l )) 

then,  press  1^™] .  In  RPN  mode,  type  the  function  definition  between 
apostrophes: 

'f(x)  =  IFTE(x>0,  x"2-l,  2*x-l)' 

then  press  I  *-\  jpg  . 

Press  [  VAR  J  to  recover  your  variable  menu.    The  function  iuiil  should  be 
available  in  your  soft  key  menu.  Press  I  r»  j8E3n  to  see  the  resulting  program: 
«  ^  X  'IFTE(x>0,  x'^2-1,  2*x-l)'  » 

To  evaluate  the  function  in  ALG  mode,  type  the  function  name,  f,  followed  by 
the  number  at  which  you  want  to  evaluate  the  function,  e.g.,  f(2),  then  press 
ISfBi .  In  RPN  mode,  enter  a  number  and  press  iS3B.  Check,  for  example, 
that  f(2)  =  3,  while  f(-2)  =  -5. 

Combined  IFTE  functions 

To  program  a  more  complicated  function  such  as 

-X,    X  <-2 
jc  +  1,  -2<x<0 
x-\,  0<x<2 
x^,    X  >  2 


you  can  combine  several  levels  of  the  IFTE  function,  i.e., 

'g(x)  =  IFTE(x<-2,  -x,  IFTE(x<0,  x+1,  IFTE(x<2,  x-1,  x'^2)))'. 
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Define  this  function  by  any  of  the  means  presented  above,  and  check  that 
g(-3)  =  3,  g(-l)  =  a  g(l)  =  0,  g(3)  =  9. 
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Chapter  4 

Calculations  with  complex  numbers 

This  chapter  shows  examples  of  calculations  and  application  of  functions  to 
complex  numbers. 

Definitions 

A  complex  number  z  is  a  number  written  as  z  =  x  +  iy,  where  x  and  y  are 
real  numbers,  and  /  is  the  imaginary  unit  defined  by    =  -1 .   The  complex 
number  x+iy  has  a  real  part,  x  =  Re(z),  and  an  imaginary  part,  y  =  lm(z). 
We  can  think  of  a  complex  number  as  a  point  P(x,y)  in  the  x-y  plane,  with  the 
x-axis  referred  to  as  the  real  axis,  and  the  y-axis  referred  to  as  the  imaginary 
axis.  Thus,  a  complex  number  represented  in  the  form  x+iy  is  said  to  be  in  its 
Cartesian  representation.  An  alternative  Cartesian  representation  is  the 
ordered  pair  z  =  (x,y).  A  complex  number  can  also  be  represented  in  polar 
coordinates  (polar  representation)  as  z  =  re'^  =  r  cos9+  i  r-sinO,  where  r  = 

/z/  =^x^  +      is  the  magnitude  of  the  complex  number  z,  and  0=  Arg(z)  = 

arctan(y/x)  is  the  argument  of  the  complex  number  z.  The  relationship 
between  the  Cartesian  and  polar  representation  of  complex  numbers  is  given 
by  the  Euler  formula:  e  '*'=  cos  6+  i  sin  0.    The  complex  conjugate  of  a 
complex  number  z  =  x  +  iy  =  re     \s  z  =  x  -  iy  =  re       The  complex 
conjugate  of  /  can  be  thought  of  as  the  reflection  of  z  about  the  real  (x)  axis. 
Similarly,  the  negative  of  z,  -z  =  -x-iy  =  -  re     can  be  thought  of  as  the 
reflection  of  z  about  the  origin. 


Setting  the  calculator  to  COMPLEX  mode 

when  working  with  complex  numbers  it  is  a  good  idea  to  set  the  calculator  to 
complex  mode,  use  the  following  keystrokes:  ImodeJ,.,  ""I!  LJJ CD ii^iiSilil 
The  COMPLEX  mode  will  be  selected  if  the  CAS  MODES  screen  shows  the 
option  _Complex  checked  off,  i.e., 


_nuM<rit  _Hippr*x  QC«Hpt«^ 
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Press  iilBlli,  twice,  to  return  to  the  stack. 
Entering  complex  numbers 

Complex  numbers  in  the  calculator  can  be  entered  in  either  of  the  two 
Cartesian  representations,  namely,  x+iy,  or  (x,y).   The  results  in  the  calculator 
will  be  shown  in  the  ordered-pair  format,  i.e.,  (x,y).  For  example,  with  the 
calculator  in  ALG  mode,  the  complex  number  (3.5,-^-2),  is  entered  as: 


A  complex  number  can  also  be  entered  in  the  form  x+iy.  For  example,  in 
ALG  mode,  3.5-1 .2i  is  entered  as: 


The  following  screen  results  after  entering  these  complex  numbers: 


(3.5,-1.2) 
3.5-1.2.i 


(3.5,-1.2) 
(3.5,-1.2) 


EDIT   VIEH    RCL  ^TO^  PURGE  CLEHR 


In  RPN  mode,  these  numbers  will  be  entered  using  the  following  keystrokes: 

(Notice  that  the  change-sign  keystroke  is  entered  after  the  number  1 .2  has 
been  entered,  in  the  opposite  order  as  the  ALG  mode  exercise),  and 


(Notice  the  need  to  enter  an  apostrophe  before  typing  the  number  3.5-1 .2i  in 
RPN  mode).  The  resulting  RPN  screen  will  be: 


(3.5,-1.2) 
3.5-1.2'i 


EDIT   VIEH    RCL  ^TD^  PURGE  CLEHR 


Notice  that  the  last  entry  shows  a  complex  number  in  the  form  x+iy.  This  is  so 
because  the  number  was  entered  between  apostrophes,  which  represents  an 
algebraic  expression.  To  evaluate  this  number  use  the  EVAL  key(  d^T)). 


2: 

(3.5,-1.2) 

l: 

(3.5,-1.2) 

EDIT  1  VIEH  1  RCL 

1  ^^^!^  IPURGEICLEHR 

Once  the  algebraic  expression  is  evaluated,  you  recover  the  complex  number 
(3.5,1.2). 
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Polar  representation  of  a  complex  number 

The  result  shown  above  represents  a  Cartesian  (rectangular)  representation  of 
the  complex  number  3.5-1 .2i.   A  polar  representation  is  possible  if  we 
change  the  coordinate  system  to  cylindrical  or  polar,  by  using  function  CYLIN. 
You  can  find  this  function  in  the  catalog  ([  r»  J  cat  ).   Changing  to  polar 
shows  the  result: 


EDIT  I  VIEH  I^THCKl  RCL  IPURGEICLEHR 


For  this  result  the  angular  measure  is  set  to  radians  (you  can  always  change  to 
radians  by  using  function  RAD).  The  result  shown  above  represents  a 
magnitude,  3.7,  and  an  angle  0.33029....  The  angle  symbol  (Z)  is  shown  in 
front  of  the  angle  measure. 


Return  to  Cartesian  or  rectangular  coordinates  by  using  function  RECT 
(available  in  the  catalog,  Ij^l  cat  ).   A  complex  number  in  polar 
representation  is  written  as  z  =  r  e'®.  You  can  enter  this  complex  number  into 
the  calculator  by  using  an  ordered  pair  of  the  form  (r,  Z0).  The  angle  symbol 
(Z)  can  be  entered  as  J[  6  J .     For  example,  the  complex  number  z  = 

5.2e^^',  can  be  entered  as  follows  (the  figures  show  the  stack,  before  and 
after  entering  the  number): 


l: 

(3.5,  1.2) 

<5.2,il 

EDIT  1  VIEH 

ISTflCKI 

RCL  IRURGEICLEHR 

2:  (3.5,1.2) 
l:  (.367333443672,5. 13^ 


Because  the  coordinate  system  is  set  to  rectangular  (or  Cartesian),  the 
calculator  automatically  converts  the  number  entered  to  Cartesian  coordinates, 
i.e.,  x  =  r  cos  0,  y  =  r  sin  0,  resulting,  for  this  case,  in  (0.3678...,  5.1 8...). 

On  the  other  hand,  if  the  coordinate  system  is  set  to  cylindrical  coordinates 
(use  CYLIN),  entering  a  complex  number  (x,y),  where  x  and  y  are  real 
numbers,  will  produce  a  polar  representation.  For  example,  in  cylindrical 
coordinates,  enter  the  number  (3. ,2.).  The  figure  below  shows  the  RPN  stack, 
before  and  after  entering  this  number: 
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1 : 

(:3,24  

^:  [3.60555127546,^. 53 ► 

EDITIVIEHI  RCL  |  £T0^  IPURGEICLEHR 

Simple  operations  with  complex  numbers 

Complex  numbers  can  be  combined  using  the  four  fundamental  operations 
([  +  JL  —  Jl  X  J(.    J).  The  results  follow  the  rules  of  algebra  with  the  caveat  that 
i^=  -  7.   Operations  with  complex  numbers  are  similar  to  those  with  real 
numbers.  For  example,  with  the  calculator  in  ALG  mode  and  the  CAS  set  to 
Complex,  we'll  attempt  the  following  sum:  (3+5i)  +  (6-3i): 

:3.+5.'i+6.-3.'i 

[3. ,2.) 


EDITIVIEHI  RCL  |  £T0^  IPURGEICLEHR 


Notice  that  the  real  parts  (3+6)  and  imaginary  parts  (5-3)  are  combined 
together  and  the  result  given  as  an  ordered  pair  with  real  part  9  and 
imaginary  part  2.    Try  the  following  operations  on  your  own: 

(5-2i)  ■  (3+4i)  =(2,-6) 
(3-i)-(2-4i)  =  (2,-14) 
(5-2i)/(3+4i)  =  (0.28,-1.04) 
l/(3+4i)  =  (0.12,  -0.16) 

Notes: 

The  product  of  two  numbers  is  represented  by:  (xi-i-iyi)(x2-i-iy2)  =  (xiX2  -  yiy2)  -i- 

i  (x,y2  -I-  xjyi). 

The  division  of  two  complex  numbers  is  accomplished  by  multiplying  both 
numerator  and  denominator  by  the  complex  conjugate  of  the  denominator, 
i.e., 

2  2  2  2 

+  iy2        ^2  +  iy2     ^2  ~  ^yi  ^2  +  J'2  -^2  +  J^2 

Thus,  the  inverse  function  INV  (activated  with  the  [    J  key)  is  defined  as 

1          \      x-iy        X        .  y 
 =  —  =  h  /  

x  +  iy    x  +  iy  x-iy    x^  +  y^       x^  +  y^ 
Changing  sign  of  a  complex  number 

Changing  the  sign  of  a  complex  number  can  be  accomplished  by  using  the 
Gt3  key,  e.g.,  -(5-3i)  =  -5  -i-  3i 
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-(5.-3.d) 


(-5.  ,3.) 


EDIT   VIEH    RCL  ^TO^  PURGE  CLEAR 


Entering  the  unit  imaginary  number 

To  enter  the  unit  imaginary  number  type  :  L  *n  J, 


VAR£  'VAR£  VPAR 


(0.  ,  1.) 


Notice  that  the  number  /  is  entered  as  the  ordered  pair  (0, 1)  if  the  CAS  is  set 
to  APPROX  mode.  In  EXACT  mode,  the  unit  imaginary  number  is  entered  as  /. 

Other  operations 

Operations  such  as  magnitude,  argument,  real  and  imaginary  parts,  and 
complex  conjugate  are  available  through  the  CMPLX  menus  detailed  later. 

The  CMPLX  menus 

There  are  two  CMPLX  (CoMPLeX  numbers)  menus  available  in  the  calculator. 
One  is  available  through  the  MTH  menu  (introduced  in  Chapter  3)  and  one 
directly  into  the  keyboard  ([    }cmplx  ).  The  tv^o  CMPLX  menus  are  presented 
next. 


CMPLX  menu  through  the  MTH  menu 

Assuming  that  system  flag  1  1 7  is  set  to  CHOOSE  boxes  (see  Chapter  2), 
the  CMPLX  sub-menu  v/ithin  the  MTH  menu  is  accessed  by  using: 
(jn^ljum  [  9  J  nSS  .  The  following  sequence  of  screen  shots  illustrates  these 
steps: 


HATH  HERU 

H.HVPEREOLIC.  1 

5. REAL.. 

i.SflSE.. 

?.PRORARILITV.. 
3.FFT.. 

S.COHPLEK..  II 

1         1         1  ICARCL 

foH 

COHPLEK  HERU 

l.RE  1 

2.IH 

3.C-* 

H.R-< 

e.ARG  1 

1         1         1  ICARCL 

OH 

The  first  menu  (options  1  through  6)  shows  the  following  functions: 
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RE(z)     :  Real  part  of  a  complex  number 
IM(z)     :  Imaginary  part  of  a  complex  number 

C->R(z)  :  Takes  a  complex  number  (x,y)  and  separates  it  into  its  real  and 
imaginary  parts 

R^C(x,y):  Forms  the  complex  number  (x,y)  out  of  real  numbers  x  and  y 
ABS(z)  ;  Calculates  the  magnitude  of  a  complex  number  or  the  absolute  value 
of  a  real  number. 

ARG(z):  Calculates  the  argument  of  a  complex  number. 


The  remaining  options  (options  7  through  1  0)  are  the 


COMPLEX  HEnU 

S.AtfS  1 

C.HRG 

1       1       1  IcflncL 

OK 

ollowmg: 


SIGN(z)  :  Calculates  a  complex  number  of  unit  magnitude  as  z/ 1  z  | . 

NEG     :  Changes  the  sign  of  z 

CONJ(z):  Produces  the  complex  conjugate  of  z 

Examples  of  applications  of  these  functions  are  shown  next.  Recall  that,  for 
ALG  mode,  the  function  must  precede  the  argument,  while  in  RPN  mode,  you 
enter  the  argument  first,  and  then  select  the  function.  Also,  recall  that  you  can 
get  these  functions  as  soft  menus  by  changing  the  setting  of  system  flag  1 1 7 
(See  Chapter  3). 


This  first  screen  shows  functions  RE,  IM,  and  C^R.    Notice  that  the  lost 
function  returns  a  list  {3.  5.}  representing  the  real  and  imaginary  components 
of  the  complex  number: 


RE(3.-2..i) 
IM(3.-2..i) 
C->-R(3.+5.'i5 


3. 
-2. 


,  {3.  5.} 


The  following  screen  shows  functions  R^C,  ABS,  and  ARG.  Notice  that  the 
ABS  function  gets  translated  to  |  3.+5.-i  | ,  the  notation  of  the  absolute  value. 
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Also,  the  result  of  function  ARG,  which  represents  on  angle,  will  be  given  in 
the  units  of  angle  measure  currently  selected.  In  this  example,  ARG(3.+5.-i) 
1 .0303...  is  given  in  radians. 


l3.+5..il 


{3.  5 
(5.  ,2.) 


5.S30951S94Sg 
RRG(3.+5..i5 
  1 . 03037632652 


In  the  next  screen  we  present  examples  of  functions  SIGN,  NEG  (which  shows 
up  as  the  negative  sign  - ),  and  CONJ. 


1 . 030376326521 
:SIGH(-2.+3..i) 
(-.554700196225, . S320=^ 
:-(-2.+3..i) 

(2.  ,-3.) 

:C0HJ(-2.+3..i) 

(-2.  ,-3.) 


CMPLX  menu  in  keyboard 

A  second  CMPLX  menu  is  accessible  by  using  the  right-shift  option  associated 
with  the  CD  key,  i.e.,  [W^cmx ,    With  system  flag  117  set  to  CHOOSE 


COHFLEK  HEnU 


3.conj 

H.i 

e.nEG 


COHPLEK  HEnU 

3.conj 

H.i 

5.IH 

E.nEG 

?.RE 

J 

1         1         1  ICHnCLl 

OK 

The  resulting  menu  include  some  of  the  functions  already  introduced  in  the 
previous  section,  namely,  ARG,  ABS,  CONJ,  IM,  NEG,  RE,  and  SIGN.  It  also 
includes  function   /  which  serves  the  same  purpose  as  the  keystroke 

combination  I  *-\  J  J.  ,  i.e.,  to  enter  the  unit  imaginary  number  /  in  an 

expression. 


The  keyboard-base  CMPLX  menu  is  an  alternative  to  the  MTH-based  CMPLX 
menu  containing  the  basic  complex  number  functions.  Try  the  examples 
shown  earlier  using  the  keyboard-based  CMPLX  menu  for  practice. 
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Functions  applied  to  complex  numbers 

Many  of  the  keyboard-based  functions  defined  in  Chapter  3  for  real  numbers, 
e.g.,  SQ,  ,LN,  e^  LOG,  10^  SIN,  COS,  TAN,  ASIN,  ACOS,  ATAN,  can  be 
applied  to  complex  numbers.  The  result  is  another  complex  number,  as 
illustrated  in  the  following  examples.  To  apply  this  functions  use  the  same 


:SQ(3.+4..i) 

( 

-7. ,24.1 

:-J3.+4.'i 

(2. ,  1.1 

:RL0G(2.-i) 

:-66.S2S151S19, 

SIH(4.-3..i5 
[-7.61 923 1 72032 ,6.543 1* 

C0S(-5.+7..i) 
[155. 536303519, -525. 

TflH(3.+3..i5 
:- 1 .  4340315S162E-3,  1 . 


:L0G(5.+3..i) 
:.76573945S5£1, 
.  5.-4..i 

■-97.0093146996 

:LH(5.-6..i) 

12.05543693209, 

.23470U 

,  112.3U 
-.S760=> 

:RSIH(7.+3..i) 

1.71663915401,3 

:RC0S(3.+3..i) 

1.361040042712, 

:RTRH(-l.+2.d) 

1-1.33397252229 

.05714U 
-2.335?> 
,  .4023^> 

Note:  When  using  trigonometric  functions  and  their  inverses  with  complex 
numbers  the  arguments  are  no  longer  angles.  Therefore,  the  angular  measure 
selected  for  the  calculator  has  no  bearing  in  the  calculation  of  these  functions 
with  complex  arguments.  To  understand  the  way  that  trigonometric  functions, 
and  other  functions,  are  defined  for  complex  numbers  consult  a  book  on 
complex  variables. 


Functions  from  the  MTH  menu 

The  hyperbolic  functions  and  their  inverses,  as  well  as  the  Gamma,  PSI,  and 
Psi  functions  (special  functions)  were  introduced  and  applied  to  real  numbers 
in  Chapter  3.  These  functions  can  also  be  applied  to  complex  numbers  by 
following  the  procedures  presented  in  Chapter  3.  Some  examples  are  shown 
below: 


SIHH(4.-6..i) 
126. 2029676173, 7. 63034^ 
iCOSH(l.-i) 

. 333730025131 ,-. 9333=^ 
iTRHH(-l.+i) 

-1 . 0S392332734, . 2717=^ 


:RSIHH(7.-9..i) 

[3. 12644592412, -. 9073£^ 

:RC0SH(3..i) 

[1 . S1344645923, 1 . 5707=^ 

:RTRHH(l.-6..i) 

[2 .63401 239 1 45E-2 ,  - 1 .  4^ 
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The  following  screen  shows  that  functions  EXPM  and  LNPl  do  not  apply  to 
complex  numbers.  However,  functions  GAMMA,  PSI,  and  Psi  accept  complex 
numbers: 


EXPM(4.-5..i) 
EXPM(4.-5..i) 

"Bad  Rrgument  Type" 
LHPl(-9..i) 

"Bad  Rrgument  Type" 


CREflT  OPER   FACT  4UflDF  Lin  S  LinflP 


GRMMR(4.+5.d) 

. 149655327961, .31460c> 
:PSI(l.-i,3.) 
-1 . 522S7444S95, . 3172E> 
:Psi(5.+9.'i) 
.2.  30S54964207,  1 . 106SU 


Function  DROITE:  equation  of  a  straight  line 

Function  DROITE  takes  as  argument  two  complex  numbers,  say,  xi+iyi  and 
X2+iy2,  and  returns  the  equation  of  the  straight  line,  say,  y  =  a+bx,  that 
contains  the  points  (xi,yi)  and  (x2,y2).  For  example,  the  line  between  points 
A(5,-3)  and  B(6,2)  con  be  found  as  follows  (example  in  Algebraic  mode): 


DR0ITE(5-3.i.6+2.i)  , 
V=5'(X-5)+-3 


CflSCM  HELP 


Function  DROITE  is  found  in  the  command  catalog  ((.  J  cat_  ). 
Using  EVAL(ANS(1))  simplifies  the  result  to: 


DR0ITE(5-3.i.6+2.i) 

V=5.(X-5)+-3 

EVRLtRHSd)) 

Y=5'X-2S 


Page  4-9 


Chapter  5 

Algebraic  and  arithmetic  operations 

An  algebraic  object,  or  simply,  algebraic,  is  any  number,  variable  name  or 
algebraic  expression  that  can  be  operated  upon,  manipulated,  and  combined 
according  to  the  rules  of  algebra.  Examples  of  algebraic  objects  are  the 
following: 

•  A  number:  12.3,  15.2_m,  V,  'e',  'i' 

•  A  variable  name:  'a',  'ux',  'v/idth',  etc. 

•  An  expression:  'p*D'^2/4','f*(L/D)*(V'^2/(2*g))' 

•  An  equation:  'Q=(Cu/n)*A(y)*R(y)"(2/3)*So'^0.5' 

Entering  algebraic  objects 

Algebraic  objects  can  be  created  by  typing  the  object  betv/een  single  quotes 
directly  into  stack  level  1  or  by  using  the  equation  v^riter  [  J  foiv  .  For 
example,  to  enter  the  algebraic  object  '7i*D'^2/4'  directly  into  stack  level  1 

use:l  '  JL   CEJ @ CZD CS CS •  The  resulting  screen  is 

shown  next  for  both  the  ALG  mode  (left-hand  side)  and  the  RPN  mode  (right- 
hand  side):   


TT'D 

 4 

4. 

EDIT|VIEH|  RCL  |  £T0^  IPURGEICLEHR 

An  algebraic  object  can  also  be  built  in  the  Equation  Writer  and  then  sent  to 
the  stack.  The  operation  of  the  Equation  Writer  was  described  in  Chapter  2. 
As  an  exercise,  build  the  following  algebraic  object  in  the  Equation  Writer: 


EDIT  I  CUR£  I  EIG  ■!  EVHL  |FHCTO|  £IHP 


After  building  the  object,  press  to  show  it  in  the  stack  (ALG  and  RPN  modes 
shown  below): 


,    A     l_  1 

D  2.9 

2 

5- 

l: 

2 

2.9'D 

2.9'D 
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Simple  operations  with  algebraic  objects 

Algebraic  objects  can  be  added,  subtracted,  multiplied,  divided  (except  by 
zero),  raised  to  a  power,  used  as  arguments  for  a  variety  of  standard 
functions  (exponential,  logarithmic,  trigonometry,  fiyperbolic,  etc.),  as  you 
would  any  real  or  complex  number.    To  demonstrate  basic  operations  with 
algebraic  objects,  let's  create  a  couple  of  objects,  say  ';i*R'^2'  and  'g*t'^2/4', 
and  store  them  in  variables  Al  and  A2  (See  Chapter  2  to  learn  how  to  create 
variables  and  store  values  in  them).  Here  are  the  keystrokes  for  storing 

variables  Al  in  ALG  mode:CZDC5D  J  CxD(^™)0CZDCX3CD 

[alfha] (a) m  [mh),  resulting  itr  


EDITlVIEHl  RCL  |  £T0^  IPURGEICLEHR 


The  keystrokes  corresponding  to  RPN  mode  are:  CDCSDJ  I  x  J[pi^rg 

CEDCID(^(^(3CD  CsroT) 

After  storing  the  variable  A2  and  pressing  the  key,  the  screen  will  show  the 
variables  as  follows: 


In  ALG  mode,  the  following  keystrokes  will  show  a  number  of  operations  with 
the  algebraics  contained  in  variables  Ell  and  i-i'Mi  (press  I  vm  J  to  recover 
variable  menu): 


.  1  ,     ■■□■■p—iiin   -1 

C  +  ^  mMi[CNfER] 


:R1+R2 

2  2 

+R  ■TT+t  '9 

4 

mum  L  —  J  KiLSs  [enter 


4.R^ 

2 

:R1-R2 

4.R^ 

4 

.2 

TT-t  '9 

4 
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■licJil  (.  X  J 

lOI-n—IHD    1  \ 

2  2 

■TT-t  '9 

4 

2  2 
t  ■g'R  ■!! 

4 

1  1^ 

:LH(R1) 

2 

4'R  'TT 

x\ 

LhIr^'TT. 

1 — : — 1  wpxM 

i  [ENTER] 

.  Rl 
■R2 

A. 

4 

2 

4.R  ■TT 

CASDI 

'a. 

lhIr^'ttJ 

4 

e 

ICASDII 

1  1 

The  same  results  are  obtained  in  RPN  mode  if  using  the  following  keystrokes: 

.llbllil  I  -H  J 


!Ei.!iiii 


(fNTH) 


Functions  in  the  ALG  menu 

The  ALG  (Algebraic)  menu  is  available  by  using  the  keystroke  sequence 
[  r»  J  ^i^G  (associated  with  the  03  key)-   With  system  flag  1  1 7  set  to 
CHOOSE  boxes,  the  ALG  menu  shows  the  following  functions: 


ALG  HEnU 

1. COLLECT  II 

a.EKPAnD  1 

FACTOR  1 

H.LACOLLECT  1 

5.  Lin 

e.PARTFRAC  W 

HELPI         1         1  ICAnCLl 

OK 

ALG  HEnU 

H.LnCOLLECT 

5.  Lin 

S.PARTFRAC 
?. SOLVE 

s.suesT 

S.TEKPAHD 

HELPI      1      1  IcAiiciT 

OK 

Rather  than  listing  the  description  of  each  function  in  this  manual,  the  user  is 
invited  to  look  up  the  description  using  the  calculator's  help  facility:  [roaj  [nxt) 
tS^sM  [ENTEK) .  To  locate  a  particular  function,  type  the  first  letter  of  the  function. 
For  example,  for  function  COLLECT,  we  type  1^51™) g] ,  then  use  the  up  and 
down  arrow  keys,  ("^"sV? ,  to  locate  COLLECT  within  the  help  window. 


To  complete  the  operation  press 
COLLECT: 


Here  is  the  help  screen  for  function 
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COLLECT: 

Recurs  i  ye      f  act  or  i  za- 
tion  of  a  polynomial 
oyer  integers 
C0LLECTtX^2-4> 

See:   EXPRHD  FRCTOR 


EXIT  I  ECHO  I  SEEl  |  SEE2  |  SEE?  |  HAIH 


We  notice  that,  at  the  bottom  of  the  screen,  the  line  See:  EXPAND  FACTOR 
suggests  links  to  other  help  facility  entries,  the  functions  EXPAND  and 
FACTOR.  To  move  directly  to  those  entries,  press  the  soft  menu  key  Eaal  for 
EXPAND,  and  Siii;!!  for  FACTOR.    Pressing  hIjIjI,  for  example,  shows  the 
following  information  for  EXPAND: 

EXPAND: 

Expancds  ancd  simplifies 
an  algebraic  expr. 
EXPRHDttX+2>*tX-2>> 

X-^2-4 

See:   COLLECT  SIMPLIFY 


EXIT  I  ECHO  I  SEEl  |  SEE2  |  SEE?  |  HAIH 


The  help  facility  provides  not  only  information  on  each  command,  but  also 
provides  an  example  of  its  application.  This  example  can  be  copied  onto 
your  stack  by  pressing  the  ''!!'!!'■'"''  soft  menu  key.  For  example,  for  the  EXPAND 
entry  shown  above,  press  the  in™ji  soft  menu  key  to  get  the  following  example 
copied  to  the  stack  (press  [g™j  to  execute  the  command): 

:HELP 

:EXPRHD((X+2>(X-2)) 


Thus,  we  leave  for  the  user  to  explore  the  applications  of  the  functions  in  the 


ALG 

(or 

ALGB)  menu. 

This  is 

a  list  o 

F  the 

commands: 

ALG  HEnU 

ALC  HERU 

1. COLLECT  II 

H.LnCOLLECT  [] 

2.  EHPAnD 

3.  FACTOR 
H.LRCOLLECT 

5.  Lin 

5.  Lin 

e.PARTFRAC  | 
7. SOLVE  1 
S.SURST  1 

e.PARTFRAC 

S.TEKPAHD  II 

HELPI         1         1  ICAnCLl 

OH 

HELP  1         1         1  ICAnCLl 

OH 
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The  help  facility  will  show  the  following  information  on  the  commands: 


COLLECT: 


COLLECT: 
Recurs  i  ye      f  act  or  i  za- 
tion  of  a  polynomial 
oyer  integers 
C0LLECTtX^2-4> 

See:   EXPRHD  FRCTOR 


EXIT   ECHO   f  EEl   £EE2  HHIH 


EXPAND: 


:xpmD: 

ixpands  and  simplifies 
an  algebraic  expr. 
:XPRHDKX+2>*tX-2>> 

X-^2-41 

See:   COLLECT  SIMPLIFY 


EXIT   ECHO   £EE1   £EE2   £EE?  HHIH 


FACTOR: 


■actorizes  an  integer 
3r  a  polynomial 
■RCT0RtX^2-2> 

tX+T2KX-r2> 

See:   EXPRHD  COLLECT 


EHIT   ECHO   £EE1   £EE2   £EE?  HHIH 


NCOLLECT: 


LHCOLLECT: 
Collects  logarithims 
LHCOLLECTtLRtX>+LHtY>  > 
LHtX*Y> 


See:  TEXPRHD 


EHIT   ECHO   f  EEl   £EE2   iZZ3  HHIH 


UN: 


Linearization  of 
exponent  ials 
LIHtEXPtX>-^2> 


EXPt2*X> 


See:   TEXPRHD  TLIH 


EHIT   ECHO   f  EEl   £EE2  HHIH 


PARTFRAC: 


^TFRflC: 
Performs  partial  frac- 
■  ion  decomposition  on 

f ract  ion 
^RRTFRRCt2X-^2/tX-^2-n  > 

2+1/tx-n-i/tx+n 

iee:  PROPFRRC 


EHIT   ECHO   £EE1   £EE2   £EE?  HHIH 


SOLVE: 


SOLVE: 

Solves  a  tor  a  set  of? 
olynomial  equation 
0L9EtX-^4-l=35.X> 

CA=T2  X=-J"2J 

feee:   LIHSOLVE  SOLVEVX 


EHIT   ECHO   f  EEl   £EE2   iZZ3  HHIH 


SUBST: 


SDBSin 

Substitutes  a  yalue 
for  a  variable  in  an 
expression 
SUESTtR-^2+l,R=2> 

2-^2+1 

See: 


EHIT   ECHO   £EE1   £EE2   iZZ3  HHIH 


TEXPAND: 


TEXF™?! 
zxpands  transcendental 
f unct  ions 
TEXPRHD<EXPtX+Y>> 

EXPtX>*EXPtY> 

feee:  LIH  TLIH 


EHIT   ECHO   £EE1   ZZZ2   ZZZ3  HHIH 
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Note:  Recall  that,  to  use  these,  or  any  other  functions  in  the  RPN  mode, 
you  must  enter  the  argument  first,  and  then  the  function.  For  example,  the 
example  for  TEXPAND,  in  RPN  mode  will  be  set  up  as: 

At  this  point,  select  function  TEXPAND  from  menu  ALG  (or  directly  from 
the  catalog  L    J  cat  ),  to  complete  the  operation. 


Other  forms  of  substitution  in  algebraic  expressions 

Functions  SUBST,  shown  above,  is  used  to  substitute  a  variable  in  an 
expression.  A  second  form  of  substitution  can  be  accomplished  by  using  the 

 L   (associated  with  the  I  key).     For  example,  in  ALG  mode,  the 

following  entry  will  substitute  the  value  x  =  2  in  the  expression  x+x^.  The 
figure  to  the  left  shows  the  way  to  enter  the  expression  (the  substituted  value, 
x=2,  must  be  enclosed  in  parentheses)  before  pressing  (fwaj .  After  the  [inter] 
key  is  pressed,  the  result  is  shown  in  the  right-hand  figure: 


x+x-^2Kx=2> 


CH^CH  HELP 


:x+x 

X=2 

2 

 2+2 

CHICHI  HELP 

1       1       1  1 

In  RPN  mode,  this  can  be  accomplished  by  entering  first  the  expression  where 
the  substitution  will  be  performed  (x+x^),  followed  by  a  list  (see  Chapter  8) 
containing  the  substitution  variable,  an  space,  and  the  value  to  be  substituted, 
i.e.,  {x  2}.  The  final  step  is  to  press  the  keystroke  combination:  L  r»  J  !, . 




3: 
2: 

^  2 



x+x 

l: 

2 

l:  

 {X  2} 

2+2 

CflSCHIHELPI         1         1         1  I 

■  CHICHI  HELP  1         1         1  1 

The  required  keystrokes  are  the  following: 
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n  ALG  mode,  substitution  of  more  than  one  variable  is  possible  as  illustrated 


in  the  fo 


lowing  example  (shown  before  and  after  pressing  [enter)) 


R+-rBKR=2,B=3>   

:  R+-J"BKR=2,B=3> 

 2+J3 

CHICHI  HELP  1         1         1         1  H 

CHICHI  HELP  1         1         1  1 

In  RPN  mode,  it  is  also  possible  to  substitute  more  than  one  variable  at  a  time, 
as  illustrated  in  the  example  below.  Recall  that  RPN  mode  uses  a  list  of 
variable  names  and  values  for  substitution. 


4: 

3: 

Z: 

r+Je 

l:  

{R  2  E  3) 

CHICHI  HELP  1         1         1  1 

4: 

3: 

2: 

l: 

2+J3 

CHICHI  HELP  1         1         1  1 

A  different  approach  to  substitution  consists  in  defining  the  substitution 
expressions  in  calculator  variables  and  placing  the  name  of  the  variables  in 
the  original  expression.  For  example,  in  ALG  mode,  store  the  following 
variables: 


:  'a+b>R 

a+b 

:'Tr+l>B 

TT+l 

Then,  enter  the  expression  A+B: 


:  'a+b>R 

a+b 

:'Tr+l>B 

TT+l 

:R+B 

TT+a+b+l 

The  last  expression  entered  is  automatically  evaluated  after  pressing  the  [enter] 
key,  producing  the  result  shown  above. 

Operations  with  transcendental  functions 

The  calculator  offers  a  number  of  functions  that  can  be  used  to  replace 
expressions  containing  logarithmic,  exponential,  trigonometric,  and 
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hyperbolic  functions  in  terms  of  trigonometric  identities  or  in  terms  of 
exponential  functions.  Thie  menus  containing  functions  to  replace 
trigonometric  functions  con  be  obtained  directly  from  tfie  keyboard  by 
pressing  the  right-shift  key  followed  by  the  8  key,  i.e.,  [    J  trig  .  The 
combination  of  this  key  with  the  left-shift  key,  i.e.,  C3  ^^^^  ,  produces  a 
menu  that  lets  you  replace  expressions  in  terms  of  exponential  or  natural 
logarithm  functions.  In  the  next  sections  we  cover  those  menus  in  more  detail. 


Expansion  and  factoring  using  log-exp  functions 

The  [  <-\  J  cxpsLN  produces  the  following  menu; 


EXP£d.n  HEnu 

l.EKPLn  II 

2.EKPH  1 

?.Lin  1 

H.LnCOLLECT  1 

s.Lnpi  1 

e.TEXPAnD  D 

HELP  1         1  1 

ICHnCLl 

OK 

EXP£:d.n  HEnu 

2.EKPH 

?.Lin 

H.LnCOLLECT 

s.Lnpi 

E.TEKPHnD 

?.t;ihp 

HELPi      1      1  Icfliiar 

OK 

Information  and  examples  on  these  commands  are  available  in  the  help 

facility  of  the  calculator.  Some  of  the  command  listed  in  the  EXP&LN  menu, 

i.e.,  LIN,  LNCOLLECT,  and  TEXPAND  are  also  contained  in  the  ALG  menu 

presented  earlier.  Functions  LNPl  and  EXPM  were  introduced  in  menu 

HYPERBOLIC,  under  the  MTH  menu  (See  Chapter  2).  The  only  remaining 

function  is  EXPLN.  Its  description  is  shown  in  the  left-hand  side,  the  example 

from  the  help  facility  is  shown  to  the  right: 

EXPLH:    

Rewrites  transcendent, 
functions  in  terms  of 
EXP  and  LH 
EXPLHtCOStX>> 
tEXPt  i*X>-H.^EXPt  i*X>  X 
5ee:   SI NCOS  EXP2HYP 


EKIT   ECHO   f  EEl   £EE2  HHIH 


:HELP 

:EXPLH(C0S(X)) 

^  i'X 
e 

2 

CHICHI  HELPI         1         1  1 

Expansion  and  factoring  using  trigonometric  functions 

The  TRIG  menu,  triggered  by  using  ( j^l  ™c  ^  shows  the  following  functions: 


TRIG  HEnu 

l.HVPEREOLIC.  1 

2.HC0£2£ 
H.flSinaT 
S.HALFTAn 

1    1  1 

ICAnCL 

OK 

TRIG  HEnu 

?.sinco;  [ 

ID.TCOLLECT 

Il.TEKPAnD  1 

nsnr^^^^Hl 

HELPI         1         1  ICAnCL 

OK 
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TRIG  HEnU 

la.TLin 

13. TRIG 
IH.TRIGCOS 
IS.TRIG^in 
IG.TRIGTHR 

i?.t;ihp  I 

HELP  1         1         1  ICHnCL 

OK 

These  functions  allow  to  simplify  expressions  by  replacing  some  category  of 
trigonometric  functions  for  another  one.  For  example,  the  function  ACOS2S 
allows  to  replace  the  function  arccosine  (acos(x))  with  its  expression  in  terms 
of  arcsine  (asin(x)). 


Description  of  these  commands  and  examples  of  their  applications  are 
available  in  the  calculator's  help  facility  ((.roaJtwrjilligS).  The  user  is  invited  to 
explore  this  facility  to  find  information  on  the  commands  in  the  TRIG  menu. 


Notice  that  the  first  command  in  the  TRIG  menu  is  the  HYPERBOLIC  menu, 
whose  functions  were  introduced  in  Chapter  2. 


Functions  in  the  ARITHMETIC  menu 

The  ARITHMETIC  menu  contains  a  number  of  sub-menus  for  specific 
applications  in  number  theory  (integers,  polynomials,  etc.),  as  well  as  a 
number  of  functions  that  apply  to  general  arithmetic  operations.  The 
ARITHMETIC  menu  is  triggered  through  the  keystroke  combination  (jT}arith_ 
(associated  with  the  QJ  key).    With  system  flag  1 1 7  set  to  CHOOSE 
boxes,  [  *i  J ^''"^  shows  the  following  menu: 


HRITH  HEnU 

l.inTEGEft..  II 

a.F-OLVnOHIHL..  1 

3.H0DUL0..  1 

H.RERHUTATIOn..  1 

:FF 

S.DIVI^ 

fi.FfiCTORS  U 

ts" 

1         1         1  iGAnCLl 

OK 

HRITH  HERU 

H.PERHUTATIOn..  [] 

S.DIVI^ 

G. FACTORS  1 

7.LGCD  1 

:FF 

S.PROF-FRAC  1 

i.smfs  II 

m         1         1  ICHnCLl 

OK 

Out  of  this  menu  list,  options  5  through  9  [DIVIS,  FACTORS,  LGCD, 
PROPFRAC,  SIMP2)  correspond  to  common  functions  that  apply  to  integer 
numbers  or  to  polynomials.    The  remaining  options  (1 .  INTEGER,  2. 
POLYNOMIAL,  3.  MODULO,  and  4.  PERMUTATION)  are  actually  sub-menus 
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of  functions  that  apply  to  specific  mathematical  objects.    This  distinction 
between  sub-menus  (options  1  through  4)  and  plain  functions  (options  5 
through  9)  is  mode  clear  when  system  flag  1 1 7  is  set  to  SOFT  menus. 
Activating  the  ARITHMETIC  menu  (C5D^^  ),  under  these  circumstances, 
produces:  ^  


I 

inTEGl  fail  IHODULI  PERM  |DIVIS|FflCTO 

■ 

LGCD  |PRCipF|SIMPa|         I  I 

Following,  we  present  the  help  facility  entries  for  the  functions  of  options  5 
through  9  in  the  ARITHMETIC  menu: 


DIVIS: 


&IVIS: 

List  of  divisors  of  a 
polynomial  or  integer 

{16  3  2  131 

See:  FRCTOR 


EXIT   ECHO   f  EEl   £EE2   iZZ3  HHIH 


FACTORS: 


Returns  irreductible 
factors  of  an  integer 
Dr  a  polynomial 
-RCT0RS<R-^2-n 

t  X+1  1.  X-1  1.  31 
See:  FRCTOR 


EXIT   ECHO   £EE1   £EE2   iZZ3  HHIH 


GCD  (Greatest  Common  Denominator): 

GCD  of  a  list  of 
objects 

LGCDai25,75,353> 


See:  GCD 


EHIT   ECHO   ZZZl   ZZZ2   ZZZ3  HHIH 


PROPFRAC  (proper  fraction) 


^ROPFRflC 
Splits  a  fraction  into 
an  integer  part  and  a 
■raction  part 
^R0PFRRCt43/12> 

3+7.^12j 

iee:  PRRTFRRC 


EHIT   ECHO   ZZZl   ZZZ2   ZZZ3  HHIH 


SIMP2: 
5IMP2: 

Simplifies  2  objects 
oy  dividing  thiem  by 
tFieir  GCD 

SIMP2tX-^3-l,X-^2-n 

{:X^2+X+1,X+13 

See: 


EHIT  I  ECHO  I  iZZl  \  £EE2  |  iZZ3  \  HHIH 


The  functions  associated  with  the  ARITHMETIC  submenus:  INTEGER, 
POLYNOMIAL,  MODULO,  and  PERMUTATION,  are  the  following: 

INTEGER  menu 

EULER         Number  of  integers  <  n,  co  -prime  with  n 
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lABCUV      Solves  au  +  bv  =  c,  with  a,b,c  =  integers 

IBERNOULLl  n-th  Bernoulli  number 

ICHINREM  Chinese  reminder  for  integers 

IDIV2         Euclidean  division  of  two  integers 

lEGCD        Returns  u,v,  such  that  au  +  bv  =  gcd(a,b) 

IQUOT       Euclidean  quotient  of  two  integers 

IREMAINDER  Euclidean  remainder  of  two  integers 

ISPRIME?     Test  if  an  integer  number  is  prime 

NEXTPRIME  Next  prime  for  a  given  integer  number 

PA2B2        Prime  number  as  square  norm  of  a  complex  number 

PREVPRIME  Previous  prime  for  a  given  integer  number 


POLYNOMIAL  menu 

ABCUV       Bezout  polynomial  equation  (au+bv=c) 

CHINREM   Chinese  remainder  for  polynomials 

CYCLOTOMIC  n-th  cyclotomic  polynomial 

DIV2  Euclidean  division  of  two  polynomials 

EGDC        Returns  u,v,  from  au+bv=gcd(a,b) 

FACTOR     Factorizes  an  integer  number  or  a  polynomial 

FCOEF       Generates  fraction  given  roots  and  multiplicity 

FROOTS      Returns  roots  and  multiplicity  given  a  fraction 

GCD  Greatest  common  divisor  of  2  numbers  or  polynomials 

HERMITE     n-th  degree  Hermite  polynomial 

HORNER     Horner  evaluation  of  a  polynomial 

LAGRANGE  Lagrange  polynomial  interpolation 

LCM  Lowest  common  multiple  of  2  numbers  or  polynomials 

LEGENDRE  n-th  degree  Legendre  polynomial 

PARTFRAC  Partial-fraction  decomposition  of  a  given  fraction 

PCOEF        (help-facility  entry  missing) 

PTAYL         Returns  Q(x-a)  in  Q(x-a)  =  P(x),  Taylor  polynomial 

QUOT        Euclidean  quotient  of  two  polynomials 

RESULTANT  Determinant  of  the  Sylvester  matrix  of  2  polynomials 

REMAINDER  Euclidean  reminder  of  two  polynomials 

STURM       Sturm  sequences  for  a  polynomial 

STURMAB  Sign  at  low  bound  and  number  of  zeros  between  bounds 
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MODULO  menu 

ADDTMOD    Add  two  expressions  modulo  current  modulus 
DIVMOD       Divides  2  polynomials  modulo  current  modulus 
DIV2MOD     Euclidean  division  of  2  polynomials  with  modular 

coefficients 

EXPANDMOD  Expands/simplify  polynomial  modulo  current  modulus 
FACTORMOD  Factorize  a  polynomial  modulo  current  modulus 
GCDMOD     GCD  of  2  polynomials  modulo  current  modulus 
INVMOD      inverse  of  integer  modulo  current  modulus 
MOD  (not  entry  available  in  the  help  facility) 

MODSTO     Changes  modulo  setting  to  specified  value 
MULTMOD    Multiplication  of  two  polynomials  modulo  current  modulus 
POWMOD    Raises  polynomial  to  a  power  modulo  current  modulus 
SUBTMOD    Subtraction  of  2  polynomials  modulo  current  modulus 


Applications  of  the  ARITHMETIC  menu 

This  section  is  intended  to  present  some  of  the  background  necessary  for 
application  of  the  ARITHMETIC  menu  functions.  Definitions  are  presented  next 
regarding  the  subjects  of  polynomials,  polynomial  fractions  and  modular 
arithmetic.   The  examples  presented  below  are  presented  independently  of 
the  calculator  setting  (ALG  or  RPN) 

Modular  arithmetic 

Consider  a  counting  system  of  integer  numbers  that  periodically  cycles  back 
on  itself  and  starts  again,  such  as  the  hours  in  a  clock.  Such  counting  system 
is  called  a  ring.  Because  the  number  of  integers  used  in  a  ring  is  finite,  the 
arithmetic  in  this  ring  is  called  finite  arithmetic.  Let  our  system  of  finite  integer 
numbers  consists  of  the  numbers  0,  1,  2,  3,  n-T,  n.  We  can  also  refer  to 
the  arithmetic  of  this  counting  system  as  modular  arithmetic  of  modulus  n.  In 
the  case  of  the  hours  of  a  clock,  the  modulus  is  1 2.  (If  working  with  modular 
arithmetic  using  the  hours  in  a  clock,  however,  we  would  have  to  use  the 
integer  numbers  0,  1 ,  2,  3,       1 0,  1 1 ,  rather  than  1 ,  2,  3,...,1 1 ,  12). 
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Operations  in  modular  arithmetic 

Addition  in  modular  arithmetic  of  modulus  n,  which  is  a  positive  integer, 
follow  the  rules  that  if  /'  and  k  are  any  two  nonnegative  integer  numbers,  both 
smaller  than  n,  if  j+k>  n,  then  j+k  is  defined  as  j+k-n.  For  example,  in  the 
case  of  the  clock,  i.e.,  for  n  =  1  2,  6+9  "="  3.  To  distinguish  this  'equality' 
from  infinite  arithmetic  equalities,  the  symbol  =  is  used  in  place  of  the  equal 
sign,  and  the  relationship  between  the  numbers  is  referred  to  as  a  congruence 
rather  than  an  equality.  Thus,  for  the  previous  example  we  would  write  6+9  = 
3  (mod  12),  and  read  this  expression  as  "six  plus  nine  is  congruent  to  three, 
modulus  twelve."  If  the  numbers  represent  the  hours  since  midnight,  for 
example,  the  congruence  6+9  =  3  (mod  1 2),  can  be  interpreted  as  saying 
that  "six  hours  past  the  ninth  hour  after  midnight  will  be  three  hours  past 
noon."  Other  sums  that  can  be  defined  in  modulus  12  arithmetic  are:  2+5  = 
7  (mod  1  2);  2+10  =  0  (mod  1  2);  7+5  =  0  (mod  1  2);  etcetera. 

The  rule  for  subtraction  will  be  such  that  if  /  -  /c  <  0,  then  j-k  is  defined  as  j-k+n. 
Therefore,  8-70  =  2  (mod  12),  is  read  "eight  minus  ten  is  congruent  to  two, 
modulus  twelve."  Other  examples  of  subtraction  in  modulus  1 2  arithmetic 
would  be  10-5  =  5  (mod  1 2);  6-9  =  9  (mod  1 2);  5  -  8  =  9  (mod  1 2);  5-10 
=  7  (mod  1  2);  etcetera. 

Multiplication  follows  the  rule  that  if  j-k  >  n,  so  that  j-k  =  m-n  +  r,  where  m  and 
rare  nonnegative  integers,  both  less  than  n,  then  j-k  =  r  [mod  n).  The  result  of 
multiplying  /  times  k  in  modulus  n  arithmetic  is,  in  essence,  the  integer 
remainder  of  j-k/ n  in  infinite  arithmetic,  if  /  /on.  For  example,  in  modulus  12 
arithmetic  we  have  7-3  =  21  =12  +  9,  (or,  7-3/12  =  21/12  =  1  +  9/12, 
i.e.,  the  integer  reminder  of  21/12  is  9).  We  can  now  write  7-3  =  9  (mod 
1  2),  and  read  the  latter  result  as  "seven  times  three  is  congruent  to  nine, 
modulus  twelve." 

The  operation  of  division  can  be  defined  in  terms  of  multiplication  as  follows, 
r/k  =  j  (mod  n),  if,  j-k  =  r  (mod  n).  This  means  that  r  must  be  the  remainder 
of  j-k/n.  For  example,  9/7  =  3  (mod  1 2),  because  7-3  =  9  (mod  1 2).  Some 
divisions  are  not  permitted  in  modular  arithmetic.  For  example,  in  modulus  1  2 
arithmetic  you  cannot  define  5/6  (mod  12)  because  the  multiplication  table  of 
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6  does  not  show  the  result  5  in  modulus  1 2  arithmetic.  This  multiplication 
table  is  shown  below: 


6*0  (mod  12) 

0 

6*6  (mod  12) 

0 

6*1  (mod  12) 

6 

6*7  (mod  12) 

6 

6*2  (mod  12) 

0 

6*8  (mod  12) 

0 

6*3  (mod  12) 

6 

6*9  (mod  12) 

6 

6*4  (mod  12) 

0 

6*10  (mod  12) 

0 

6*5  (mod  12) 

6 

6*1 1  (mod  12) 

6 

Formal  definition  of  a  finite  arithmetic  ring 

The  expression  a  =  b  (mod  n)  is  interpreted  as  "a  is  congruent  to  b,  modulo 
n,"  and  holds  if  (b-a)  is  a  multiple  of  n.    With  this  definition  the  rules  of 
arithmetic  simplify  to  the  following: 

If  a  =  b  (mod  n)  and  c  =  ol  fmocf  n), 

then 

a+c  =  b+d  (mod  n), 
a-c  =  b  -  d  (mod  n), 

axe  =  bxd  (mod  n). 

For  division,  follow  the  rules  presented  earlier.  For  example,  17  =  5  (mod  6), 
and  21=3  (mod  6).  Using  these  rules,  we  can  write: 

17  +  21=5  +  3  (mod  6)  =>   38  =  8  (mod  6)    =>  38  =  2  (mod  6) 
17-21=5-3  (mod  6)  =>     -4=2  (mod  6) 

17x21=5x3  (mod  6)  =>   357  =  15  (mod  6)  =>  357  =  3  (mod  6) 

Notice  that,  whenever  a  result  in  the  right-hand  side  of  the  "congruence" 
symbol  produces  a  result  that  is  larger  than  the  modulo  (in  this  case,  n  =  6), 
you  can  always  subtract  a  multiple  of  the  modulo  from  that  result  and  simplify 
it  to  a  number  smaller  than  the  modulo.  Thus,  the  results  in  the  first  case  8 
(mod  6)  simplifies  to  2  (mod  6),  and  the  result  of  the  third  case,  75  (mod  6) 
simplifies  to  3  (mod  6).  Confusing?  Well,  not  if  you  let  the  calculator  handle 
those  operations.  Thus,  read  the  following  section  to  understand  how  finite 
arithmetic  rings  are  operated  upon  in  your  calculator. 
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Finite  arithmetic  rings  in  the  calculator 

All  along  we  have  defined  our  finite  arithmetic  operation  so  that  the  results 
are  always  positive.  The  modular  arithmetic  system  in  the  calculator  is  set  so 
that  the  ring  of  modulus  n  includes  the  numbers  ■n/2+7,  0,  1  ,...,n/2-l , 

n/2,  if  n  is  even,  and  -(n-l)/2,  -(n-3)/2,...,-l ,0,1  ,...,(n-3)/2,  (n-l)/2,  if  n  is 
odd.  For  example,  for  n  =  8  (even),  the  finite  arithmetic  ring  in  the  calculator 
includes  the  numbers:  (-3,-2,-1,0,1,3,4),  while  for  n  =  7  (odd),  the 
corresponding  calculator's  finite  arithmetic  ring  is  given  by  (-3,-2,-1,0,1,2,3). 

Modular  arithmetic  in  the  calculator 

To  launch  the  modular  arithmetic  menu  in  the  calculator  select  the  MODULO 
sub-menu  within  the  ARITHMETIC  menu  (I Jn,l arith  ).  The  available  menu 
includes  functions:  ADDTMOD,  DIVMOD,  DIV2MOD,  EXPANDMOD, 
FACTORMOD,  GCDMOD,  INVMOD,  MOD,  MODSTO,  MULTMOD, 
POWMOD,  and  SUBTMOD.  Brief  descriptions  of  these  functions  were 
provided  in  an  earlier  section.  Next  we  present  some  applications  of  these 
functions. 

Setting  the  modulus  (or  MODULO) 

The  calculator  contains  a  variable  called  MODULO  that  is  placed  in  the 
{HOME  CASDIR}  directory  and  will  store  the  magnitude  of  the  modulus  to  be 
used  in  modular  arithmetic. 

The  default  value  of  MODULO  is  1  3.   To  change  the  value  of  MODULO,  you 
can  either  store  the  new  value  directly  in  the  variable  MODULO  in  the  sub- 
directory {HOME  CASDIR}  Alternatively,  you  can  store  a  new  MODULO 
value  by  using  function  MODSTO. 

Modular  arithmetic  operations  with  numbers 

To  add,  subtract,  multiply,  divide,  and  raise  to  a  power  using  modular 
arithmetic  you  will  use  the  functions  ADDTMOD,  SUBTMOD,  MULTMOD, 
DIV2MOD  and  DIVMOD  (for  division),  and  POWMOD.  In  RPN  mode  you 
need  to  enter  the  two  numbers  to  operate  upon,  separated  by  an  [ENTER]  or 
an  [SPC]  entry,  and  then  press  the  corresponding  modular  arithmetic  function. 
For  example,  using  a  modulus  of  1  2,  try  the  following  operations: 
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ADDTMOD  examples 

6+5  =  -1  (mod  1 2) 
11+5  =  4  (mod  12) 

SUBTMOD  examples 

5-  7^-2  (mod  1 2) 
11-8  =  3  (mod  1 2) 

MULTMOD  examples 

6-  8  =  0  (mod  1 2) 
5-6  =  6  (mod  12) 

DIVMOD  examples 

12/3  =  4  (mod  1 2) 
25/5  =  5  (mod  1 2) 
66/6  =  -1  (mod  1 2) 

DIV2MOD  examples 

2/3  (mod  1  2)  does  not  exist 

26/1 2  (mod  1  2)  does  not  exist 

1 25/1 7  (mod  1  2)  =  1  with  remainder  =  0 

68/7  =  -4  (mod  1 2)  with  remainder  =  0 

7/5  =  -1  (mod  1 2)  with  remainder  =  0 


Note:  DIVMOD  provides  the  quotient  of  the  modular  division  j/k  (mod  n), 
while  DIMV2MOD  provides  no  only  the  quotient  but  also  the  remainder  of  the 
modular  division  j/k  (mod  n). 


POWMOD  examples 

22^-4  (mod  12)  3^^  3  (mod  1  2)  5i°^l(modl2) 

lP=l(modl2)         6^=0  (mod  12)  9'=-3(modl2) 

In  the  examples  of  modular  arithmetic  operations  shown  above,  we  have  used 

numbers  that  not  necessarily  belong  to  the  ring,  i.e.,  numbers  such  as  66, 
1 25,  1 7,  etc.    The  calculator  will  convert  those  numbers  to  ring  numbers 


6+6  =  0  (mod  1 2)  6+7  =  1  (mod  1 2) 
8+10  =  -6  (mod  12) 


8-4=4(modl2)  5 -10  =  -5  (mod  12) 
8  -  1 2  =  -4  (mod  1 2) 


9-8  =  0  (mod  12)  3-2  =  6  (mod  12) 
1 1  -3  =  -3  (mod  1 2) 


1 2/8  (mod  1  2)  does  not  exist 
64/13  =4  (mod  12) 
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before  operating  on  them.  You  con  also  convert  any  number  into  a  ring 
number  by  using  the  function  EXPANDMOD.  For  example, 

EXPANDMOD(l  25)  ^  5  (mod  1  2) 
EXPANDMOD(l  7)   ^  5  (mod  1  2) 
EXPANDMOD(6)  =  6  (mod  1 2) 

The  modular  inverse  of  a  number 

Let  a  number  k  belong  to  a  finite  arithmetic  ring  of  modulus  n,  then  the 
modular  inverse  of  k,  i.e.,  ?//c  fmod  n),  is  a  number  /,  such  that  /-/c  =  7  (mod 
n).  The  modular  inverse  of  a  number  can  be  obtained  by  using  the  function 
INVMOD  in  the  MODULO  sub-menu  of  the  ARITHMETIC  menu.  For  example, 
in  modulus  12  arithmetic: 

1  / 6  (mod  1  2)  does  not  exist.  1/5  =  5  (mod  1  2) 

1/7  =  -5  (mod  12)  1/3  (mod  1  2)  does  not  exist. 

1/11  =-1  (mod  12) 

The  MOD  operator 

The  MOD  operator  is  used  to  obtain  the  ring  number  of  a  given  modulus 
corresponding  to  a  given  integer  number.  On  paper  this  operation  is  v^ritten 
as  m  mod  n  =  p,  and  is  read  as  "m  modulo  n  is  equal  to  p".  For  example, 
to  calculate  1 5  mod  8,  enter: 

•  ALGmode:       CTDCS  MOD  C1D(»S) 

•  RPN  mode:       CX)C1D(^CID(^  MOD 

The  result  is  7,  i.e.,  15  mod  8  =  7.  Try  the  follov/ing  exercises: 
1 8  mod  1 1  =  7  23  mod  2  =1  40  mod  1 3  =  1 

23  mod  17  =  6  34  mod  6  =  4 

One  practical  application  of  the  MOD  function  for  programming  purposes  is 
to  determine  v/hen  an  integer  number  is  odd  or  even,  since  n  mod  2  =  0,  if  n 
is  even,  and  n  mode  2  =  1,  if  n  is  odd.  It  can  also  be  used  to  determine 
when  an  integer  m  is  a  multiple  of  another  integer  n,  for  if  that  is  the  case  m 

mod  n  =  0. 


Page  5-1 7 


Note:  Refer  to  the  help  facility  in  the  calculator  for  description  and  examples 
on  other  modular  arithmetic.  Many  of  these  functions  are  applicable  to 
polynomials.  For  information  on  modular  arithmetic  with  polynomials  please 
refer  to  a  textbook  on  number  theory. 


Polynomials 

Polynomials  are  algebraic  expressions  consisting  of  one  or  more  terms 
containing  decreasing  powers  of  a  given  variable.  For  example, 
'X'^3+2*X'^2-3*X+2'  is  a  third-order  polynomial  in  X,  while  'SIN(X)'^2-2'  is  a 
second-order  polynomial  in  SIN(X).   A  listing  of  polynomial-related  functions 
in  the  ARITHMETIC  menu  was  presented  earlier.  Some  general  definitions  on 
polynomials  are  provided  next.    In  these  definitions  A(X),  B(X),  C(X),  P(X), 
Q(X),  U(X),  V(X),  etc.,  are  polynomials. 

•  Polynomial  fraction:  a  fraction  whose  numerator  and  denominator  are 
polynomials,  say,  C(X)  =  A(X)/B(X) 

•  Roots,  or  zeros,  of  a  polynomial:  values  of  X  for  which  P(X)  =  0 

•  Poles  of  a  fraction:  roots  of  the  denominator 

•  Multiplicity  of  roots  or  poles:  the  number  of  times  a  root  shows  up,  e.g., 
P(X)  =  (X-Fl)2(X-3)  has  roots  {-1,  3}  with  multiplicities  {2,1} 

•  Cyclotomic  polynomial  (Pn(X)):  a  polynomial  of  order  EULER(nj  whose 
roots  are  the  primitive  n-th  roots  of  unity,  e.g.,  P2(X)  =  X-l-1,  P4(X)  =  X^-l-1 

•  Bezout's  polynomial  equation:  A(X)  U(X)  -i-  B(X)V(X)  =  C(X) 
Specific  examples  of  polynomial  applications  are  provided  next. 

Modular  arithmetic  with  polynomials 

The  same  way  that  we  defined  a  finite-arithmetic  ring  for  numbers  in  a 

previous  section,  we  can  define  a  finite-arithmetic  ring  for  polynomials  with  a 
given  polynomial  as  modulo.  For  example,  we  can  write  a  certain  polynomial 
P(X)  as  P(X)  =  X  (mod  X^),  or  another  polynomial  Q(X)  =  X+  1  (mod  X-2). 

A  polynomial,  P(X)  belongs  to  a  finite  arithmetic  ring  of  polynomial  modulus 
M(X),  if  there  exists  a  third  polynomial  Q(X),  such  that  (P(X)  -  Q(X))  is  a 
multiple  of  M(X).  We  then  would  write:  P(X)  =  Q(X)  (mod  M(X)).  The  later 
expression  is  interpreted  as  "P(X)  is  congruent  to  Q(X),  modulo  M(X)". 
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The  CHINREM  function 

CHINREM  stands  for  CHINese  REMainder.  The  operation  coded  in  this 
command  solves  a  system  of  two  congruences  using  the  Chinese  Remainder 
Theorem.  This  command  can  be  used  with  polynomials,  as  well  as  with 
integer  numbers  (function  ICHINREM).  The  input  consists  of  two  vectors 
[expression_l ,  modulo_l]  and  [expression_2,  modulo_2].  The  output  is  a 
vector  containing  [expression_3,  modulo_3],  where  modulo_3  is  related  to  the 
product    (modulo_l)-(modulo_2).  Example:    CHINREM(['X+1 ',  'X^2- 

1'],['X+1'/X''2'])  =  ['X+1V(X''4-X'^2)] 

Statement  of  the  Chinese  Remainder  Theorem  for  integers 

If  m,,  m2,...,m,  ore  natural  numbers  every  pair  of  which  are  relatively  prime, 
and  a,,  02,      a,  are  any  integers,  then  there  is  an  integer  x  that 
simultaneously  satisfies  the  congruences:  x  =0,  (mod  m,),  x  =02  (mod 
m2),       X  =a,  (mod  mj.  Additionally,  if  x  =  a  is  any  solution  then  all  other 
solutions  are  congruent  to  a  modulo  equal  to  the  product  m,-m2- ...  m,. 

The  EGCD  function 

EGCD  stands  for  Extended  Greatest  Common  Divisor.  Given  two  polynomials, 
A(X)  and  B(X),  function  EGCD  produces  the  polynomials  C(X),  U(X),  and  V(X), 
so  that  C(X)  =  U(X)*A(X)  +  V(X)*B(X).  For  example,  for  A(X)  =  X'^2+1 ,  B(X)  = 
X^2-l,  EGCD(A(X),B(X))  =  {2,  1,  -1}.  i.e.,  2  =  1*(  X'^2+T)-l*{  X'^2-1).  Also, 
EGCD('X'^3-2*X+5','X')  =  {  5,  '-(X'^2-2)',  1},  i.e.,  5  =  -  (X'^2-2)*X  +  1  *{X'^3- 
2*X+5). 

The  GCD  function 

The  function  GCD  (Greatest  Common  Denominator)  can  be  used  to  obtain  the 
greatest  common  denominator  of  two  polynomials  or  of  two  lists  of 
polynomials  of  the  same  length.  The  two  polynomials  or  lists  of  polynomials 
will  be  placed  in  stack  levels  2  and  1  before  using  GCD.  The  results  will  be  a 
polynomial  or  a  list  representing  the  greatest  common  denominator  of  the  two 
polynomials  or  of  each  list  of  polynomials.  Examples,  in  RPN  mode,  follow 
(calculator  set  to  Exact  mode): 
'X'^3-1'(^'X'^2-1'(^GCD  Results  in:  'X-T 

{'X"2+2*X+1','X'^3+X'^2'}  {'X^3+1','X'^2+1'}  GCD  results  in 

{'X+V  1} 
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The  HERMITE  function 

The  function  HERMITE  [HERMI]  uses  as  argument  on  integer  number,  k,  and 
returns  the  Hermite  polynomial  of  k-th  degree.  A  Hermite  polynomial,  He^lx) 
is  defined  as 

He,=\,    HeSx)  =  {-\re''"^{e-''"),    n  =  \,2,... 

ax 

An  alternate  definition  of  the  Hermite  polynomials  is 

H*  =  \,    H„*{x)  =  {-\re'''^{e-^'),    n  =  \,2,... 

ax 

where  d"/dx"  =  n-th  derivative  v/ith  respect  to  x.  This  is  the  definition  used  in 
the  calculator. 

Examples:  The  Hermite  polynomials  of  orders  3  and  5  are  given  by: 

HERMITE(3)  =  '8*X'^3-12*X' 
And  HERMITE(5)=  '32*x'^5-160*X^3+l  20*X'. 

The  HORNER  function 

The  function  HORNER  produces  the  Horner  division,  or  synthetic  division,  of  a 
polynomial  P(X)  by  the  factor  (X-a).  The  input  to  the  function  are  the 
polynomial  P(X)  and  the  number  a.  The  function  returns  the  quotient 
polynomial  Q(X)  that  results  from  dividing  P(X)  by  (X-o),  the  value  of  o,  and  the 
value  of  P(o),  in  that  order.  In  other  words,  P(X)  =  Q(X)(X-a)+P(a).  For 
example,  HORNER('X'^3+2*X'^2-3*X+T,2)  =  {'X'^2+4*X+5',  2,  11}.  We 
could,  therefore,  write  )(?+2X^-^X+^  =  (X2+4X+5)(X-2)+l  1 .  A  second 
example:  HORN ERCX'^ 6-1  ',-5)=  {'X^5-5*X'^4+25*X'^3-1 25*X'^2+625*X-31 25',-5, 
15624}  i.e.,     X*-l  =  {X5-5*X^+25X3-1 25X2+625X-31 25)(X+5)+l  5624. 

The  variable  VX 

A  variable  called  VX  exists  in  the  calculator's  {HOME  CASDIR}  directory  that 
takes,  by  default,  the  value  of  'X'.  This  is  the  name  of  the  preferred 
independent  variable  for  algebraic  and  calculus  applications.  Avoid  using 
the  variable  VX  in  your  programs  or  equations,  so  as  to  not  get  it  confused 
with  the  CAS'  VX.  If  you  need  to  refer  to  the  x-component  of  velocity,  for 
example,  you  can  use  vx  or  Vx.  For  additional  information  on  the  CAS 
variable  see  Appendix  C. 
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The  LAGRANGE  function 

The  function  LAGRANGE  requires  as  input  a  matrix  having  two  rows  and  n 
columns.  The  matrix  stores  data  points  of  the  form  [[xi,X2,       xj  [y,,  yj, 
yj].  Application  of  the  function  LAGRANGE  produces  the  polynomial 
expanded  from 

n 

PnM)  =  2^—^  yj- 

k=\,k*  j 

For  example,  for  n  =  2,  we  will  write: 

x-x.         x-x  {y\-y2)-x  +  {y2-x^-y,-X2) 


Check  this  result  with  your  calculator: 

LAGRANGE([[  xl,x2],[yl,y2]])  =  '((yl-y2)*X+(y2*xl-yl  *x2))/(xl-x2)'. 

Other  examples:  LAGRANGE([[1 ,  2,  3][2,  8,  15]])  =  '(X^2+9*X-6)/2' 
LAGRANGE([[0.5,1.5,2.5,3.5,4.5][12. 2,13.5,19. 2,27.3,32.5]])  = 
'-(.1375*X'^4+  -.7666666666667*X'^3+-  .74375*X'^2  = 
1 .99 1 666666667*X-1 2.92265625)'. 


Note;  Matrices  are  introduced  in  Chapter  10. 
The  LCM  function 

The  function  LCM  (Least  Common  Multiple)  obtains  the  least  common  multiple 
of  two  polynomials  or  of  lists  of  polynomials  of  the  same  length.  Examples: 

LCM('2*X'^2+4*X+2'  ,'X'^2-1' )  =  '(2*X'^2+4*X+2)*(X-1)'. 
LCM('X'^3-1'/X^2+2*X')  =  '(X'^S-l)*!  X'^2+2*X)' 
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The  LEGENDRE  function 

A  Legendre  polynomial  of  order  n  is  a  polynomial  function  tfiat  solves  the 

d 

differential  equation  (1  - x^)  y  —  2-x-  —  +  n-  {n  +  \)-y  =  0 

dx  dx 

To  obtain  the  n-th  order  Legendre  polynomial,  use  LEGENDRE(n),  e.g., 

LEGENDRE(3)  =  '(5*X'^3-3*X)/2' 
LEGENDRE(5)  =  '(63*X  ^5-70*X'^3+l  5*X)/8' 

The  PCOEF  function 

Given  an  array  containing  the  roots  of  a  polynomial,  the  function  PCOEF 
generates  an  array  containing  the  coefficients  of  the  corresponding 
polynomial.  The  coefficients  correspond  to  decreasing  order  of  the 
independent  variable.  For  example:  PCOEF([-2,-l  ,0, 1 , 1 ,2])  =  [1 .  -1 .  -5.  5. 
4.  -4.  0.],  v/hich  represents  the  polynomial  X^-X5-5X'*+5X3+4XMX. 

The  PROOT  function 

Given  an  array  containing  the  coefficients  of  a  polynomial,  in  decreasing 
order,  the  function  PROOT  provides  the  roots  of  the  polynomial.  Example, 
from  X2+5X-6  =0,  PROOT([l,  -5,  6])  =  [2.  3.]. 

The  PTAYL  function 

Given  a  polynomial  P(X)  and  a  number  o,  the  function  PTAYL  is  used  to  obtain 
an  expression  Q(X-a)  =  P(X),  i.e.,  to  develop  a  polynomial  in  powers  of  (X-  a). 
This  is  also  knovi/n  as  a  Taylor  polynomial,  from  which  the  name  of  the 
function.  Polynomial  &  TAYLor,  follow: 

For  example,  PTAYL{'X'^3-2*X+2',2)  =  'X'^3+6*X'^2+1 0*X+6'. 

In  actuality,  you  should  interpret  this  result  to  mean 

'(X-2)  '^3+6*(X-2)  ^2+10*(X-2)  +6'. 

Let's  check  by  using  the  substitution:  'X  =  x  -  2'.  We  recover  the  original 
polynomial,  but  in  terms  of  lower-case  x  rather  than  upper-case  x. 
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The  QUOT  and  REMAINDER  functions 

The  functions  QUOT  and  REMAINDER  provide,  respectively,  the  quotient  Q(X) 
and  the  remainder  R(X),  resulting  from  dividing  tv/o  polynomials,  Pi(X)  and 
P2(X).  In  other  v^ords,  they  provide  the  values  of  Q(X)  and  R(X)  from 
Pi(X)/P2(X)  =  Q(X)  +  R(X)/P2(X).  For  example, 

QUOT(X^3-2*X+2,  X-1)  =  X'^2+X-l 
REMAINDER(X'^3-2*X+2,  X-1)  =  1. 

Thus,  v/e  can  v/rite:    (X^-2X+2)/{X-] )  =  X^+X-l  +  1/(X-1 ). 


Note:  you  could  get  the  latter  result  by  using  PROPFRAC: 

PROPFRAC('(X'^3-2*X+2)/{X-l)')  =  'X'^2+X-l  +  1/{X-1)'. 


The  EPSXO  function  and  the  CAS  variable  EPS 

The  variable  s  (epsilon)  is  typically  used  in  mathematical  textbooks  to 
represent  a  very  small  number.  The  calculator's  CAS  creates  a  variable  EPS, 
v/ith  default  value  0.0000000001  =  10^°,  v/hen  you  use  the  EPSXO  function. 
You  can  change  this  value,  once  created,  if  you  prefer  a  different  value  for 
EPS.  The  function  EPSXO,  when  applied  to  a  polynomial,  v/ill  replace  all 
coefficients  v/hose  absolute  value  is  less  than  EPS  with  a  zero.  Function 
EPSXO  is  not  available  in  the  ARITHMETIC  menu,  it  must  be  accessed  from  the 
function  catalog  (N).  Example: 

EPSXOCX'^S-l  .2E-1 2*X'^2+1 .2E-6*X+6.2E-1 1)= 

'X'^3-0*X'^2+.000001 2*X+0'. 

With  Qm) :  'X'^  3+.00000 1 2  *X' . 

The  PEVAL  function 

The  functions  PEVAL  (Polynomial  EVALuation)  can  be  used  to  evaluate  a 
polynomial  pfxj  =  an-x"+a„.|-x  "     ...+  a2-x^+a;-'^+  Oq,  given  an  array  of 
coefficients  [a„,  a„.,,  ...  02,  a,,  Og]  and  a  value  of  Xq.  The  result  is  the 
evaluation  pfxJ.  Function  PEVAL  is  not  available  in  the  ARITHMETIC  menu,  it 
must  be  accessed  from  the  function  catalog  (,N).  Example: 

PEVAL{[1,5,6,1],5)  =  281. 
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The  TCHEBYCHEFF  function 

The  function  TCHEBYCHEFF(n)  generates  the  Tchebycheff  (or  Chebyshev) 
polynomial  of  the  first  kind,  order  n,  defined  as  TJX)  =  cos(n  arccos(X)).  If  the 
integer  n  is  negative  (n  <  0),  the  function  TCHEBYCHEFF(n)  generates  the 
Tchebycheff  polynomial  of  the  second  kind,  order  n,  defined  as  T„(X)  = 
sin(n  -arccosfX))/ sin(arccos(X)).  Exa m pies : 

TCHEBYCHEFF(3)  =  4*X'^3-3*X 
TCHEBYCHEFF(-3)  =  4*X^2-1 

Fractions 

Fractions  can  be  expanded  and  factored  by  using  functions  EXPAND  and 
FACTOR,  from  the  ALG  menu  (,x).  For  example: 

EXPAND('(1  +X)'^3/((X-1  )(X+3))')  =  '(X^3+3*X'^2+3*X+1  )/(X'^2+2*X-3)' 
EXPAND('(X'^2*(X+Y)/(2*X-X'^2)'^2')  =  '(X+Y)/(X'^2-4*X+4)' 
EXPAND('X*(X+Y)/(X'^2-1)')  =  '(X'^2+Y*X)/(X'^2-1)' 
EXPAND('4+2*(X-1  )+3/({X-2)*(X+3))-5/X''2')  = 

'(2*X'^5+4*X^4-1 0*X^3-1 4*X'^2-5*X)/(X'^4+X'^3-6*X^2)' 

FACTOR('(3  *X'^  3-2  *X'^  2)/(X'^  2-5  *X-i-6)')  =  'X'^  2  *  (3  *X-2)/((X-2)  *  (X-3))' 
FACTOR('(X'^3-9*X)/(X"2-5*X+6)'  )  =  'X*(X+3)/(X-2)' 
FACTOR('(X'^2-l)/(X'^3*Y-Y)')  =  '(X-i-l)/{(X'^2-i-X-i-l)*Y)' 

TheSIMP2  function 

Functions  SIMP2  and  PROPFRAC  are  used  to  simplify  a  fraction  and  to 
produce  a  proper  fraction,  respectively.  Function  SIMP2  takes  as  arguments 
tv/o  numbers  or  polynomials,  representing  the  numerator  and  denominator  of 
a  rational  fraction,  and  returns  the  simplified  numerator  and  denominator.  For 
example:  SIMP2('X'^3-1 ','X'^2-4*X-i-3')  =  { 'X'^2-i-X+l ','X-3'}. 

The  PROPFRAC  function 

The  function  PROPFRAC  converts  a  rational  fraction  into  a  "proper"  fraction, 
i.e.,  an  integer  part  added  to  a  fractional  part,  if  such  decomposition  is 
possible.  For  example: 
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PROPFRAC('5/4')  =  '1  +  1/4' 
PROPFRAC('(x'^2+l)/x"2')  =  '1 +17x^^2' 

The  PARTFRAC  function 

The  function  PARTFRAC  decomposes  a  rational  fraction  into  thie  partial 
fractions  that  produce  the  original  fraction.  For  example: 

PARTFRAC('(2*X"6-14*X"5+29*X^4-37*X'^3+41*X'^2-16*X+5)/(X'^5- 
y*X^4+-[  ]  *X'^3-7*X'^2+1 0*X)')  = 

'2  *X+(  1  /2/(X-2)+5/(X-5)+ 1  /2/X+X/(X'^  2+ 1 ))' 

This  technique  is  useful  in  calculating  integrals  (see  chapter  on  calculus)  of 
rational  fractions. 

If  you  have  the  Complex  mode  active,  the  result  v/ill  be: 

'2  *X+(  1  /2/(X+i)+ 1  /2/(X-2)+5/(X-5)+ 1  /2/X+ 1  /2/(X-i))' 
The  FCOEF  function 

The  function  FCOEF  is  used  to  obtain  a  rational  fraction,  given  the  roots  and 
poles  of  the  fraction. 


Note:  If  a  rational  fraction  is  given  as  F(X)  =  N(X)/D(X),  the  roots  of  the 
fraction  result  from  solving  the  equation  N(X)  =  0,  while  the  poles  result  from 
solving  the  equation  D(X)  =  0. 


The  input  for  the  function  is  a  vector  listing  the  roots  followed  by  their 
multiplicity  (i.e.,  how  many  times  a  given  root  is  repeated),  and  the  poles 
followed  by  their  multiplicity  represented  as  a  negative  number.  For  example, 
if  we  wont  to  create  a  fraction  having  roots  2  with  multiplicity  1,  0  with 
multiplicity  3,  and  -5  with  multiplicity  2,  and  poles  1  with  multiplicity  2  and  -3 
with  multiplicity  5,  use: 

FCOEF([2  1  0  3-5  2  1-2-3  -5])  =  '(X~5)''2*X'^3*(X-2)/(X~3)''5*(X-l)'^2' 
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If  you  press  d^T)  you  will  get: 

'(X"6+8*X^5+5*X'^4-50*X'^3)/{X'^7+13*X'^6+61*X'^5+105*X'^4-45*X'^3- 
297*X'^2-81*X+243)' 

The  FROOTS  function 

The  function  FROOTS  obtains  the  roots  and  poles  of  a  fraction.   As  an 
example,  applying  function  FROOTS  to  the  result  produced  above,  will  result 
in:  [1  -2.  -3  -5.  0  3.  2  1.-5  2.].  The  result  shows  poles  followed  by  their 
multiplicity  as  a  negative  number,  and  roots  followed  by  their  multiplicity  as  a 
positive  number.  In  this  case,  the  poles  ore  (1,  -3)  with  multiplicities  (2,5) 
respectively,  and  the  roots  are  (0,  2,  -5)  with  multiplicities  (3,  1 ,  2), 
respectively. 

Another  example  is:  FROOTS('(X'^2-5*X+6)/(X'^5-X'^2)')=  [0 -2.1  -1.3  1.2 
1.].  i.e.,  poles  =  0  (2),  1(1),  and  roots  =  3(1),  2(1).  If  you  have  had  Complex 
mode  selected,  then  the  results  would  be: 

[0  -2.  1  -1 .  '-((1  +i*^3)/2'  -1 .  '-((1  -i*V3)/2'  -1 .]. 

Step-by-step  operations  with  polynomials  and  fractions 

By  setting  the  CAS  modes  to  Step/step  the  calculator  will  show  simplifications 
of  fractions  or  operations  with  polynomials  in  a  step-by-step  fashion.  This  is 
very  useful  to  see  the  steps  of  a  synthetic  division.  The  example  of  dividing 

-5X'  +3X-2 
X-2 

is  shown  in  detail  in  Appendix  C.  The  following  example  shows  a  lengthier 
synthetic  division: 

X'-\ 


[)  I  v2t:x-^9-i,x-^2-n   

^iyision  R=EQ-hR 
3:  {:i;0,-lJ 

a: 

?:    te, 1,0,0,0,0,0,0,-1 

^ress  a  key  to  go  on 

flECUV|CHinR|CYCLO|  DIVa  1  EGCD  |FflCTO 

flECUV|CHinR|CVCLO|  DIVa  1  EGCD  |FflCTO 
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Division  H=BQ+R 

B:  {:i,0;-n 

R:    tl, 0,0, 0,0, 0,0,-1  J 

Press  a  key  to  go  on 


^iyision  H=BQ+R 

=i:  0,0, 0,0, 0,0, 0,0, 

3:  {:i,0,-lJ 

a:  {:i,0,i> 

R:    {10,  1,0,0,0,0,-1  J 

^ress  a  key  to  go  on 


AECUV  CHinR  CYCLO  DIV2   EGCD  FACTOHARCUV  CHIRR  CVCLO  DIV2   EGCD  FACTO 


Jiyision  R=EQ+R 

=|:    <:i, 0,0, 0,0, 0,0, 0,0, 

B:  tl,0,-n 

Q:  {:1,0,1,0J 

R:  {11,0,0,0,0,-1  J 

Press  a  key  to  go  on 


Jiyision  R=EQ+R 

=i:  {:i, 0,0, 0,0, 0,0, 0,0, 

3:  {:i,0,-n 

a:  {:i,0,i,0,n 

R:  {10, 1,0,0,-1  J 
^ress  a  key  to  go  on 


ARCUVICHIRRICYCLOI  DIV2  |  ECCD  |FACTOHARCUV|CHinR|CYCLO|  DIV2  |  ECCD  IFACTO 


Jiyision  R=EQ+R 

=|:    {:i, 0,0, 0,0, 0,0, 0,0, 

B:  {:i,0,-n 

a:  {:i,0, 1,0, i,0j 

R:  {:i,0,0,-lJ 

Press  a  key  to  go  on 


Jiyision  R=EQ+R 

=i:    {:i, 0,0, 0,0, 0,0, 0,0, 

3:  {:i,0,-lJ 

a:  {:i,0, 1,0, 1,0, 1 J 

R:  {:0,1,-1J 

^ress  a  key  to  go  on 


ARCUV  CHIRR  CYCLO  DIV2   ECCD  FACTOHARCUV  CHIRR  CYCLO  DIV2   ECCD  FACTO 


^lyision  R=EQ+R 
R:    {:i, 0,0, 0,0, 0,0, 0,0, 


3:  {:i,0,-lJ 

a:  {:i,0, 1,0, 1,0, i,0j 

R:  {:i,-lJ 

^ress  a  key  to  go  on 


ARCUV  CHIRR  CYCLO  DIV2   ECCD  FACTOHARCUV  CHIRR  CYCLO  DIV2   ECCD  FACTO 


DIV2(x^-l,X^-l) 
{q:  (x'^+X^+X^+x)  R:  (X-1)} 


The  CONVERT  Menu  and  algebraic  operations 

The  CONVERT  menu  is  activated  by  using  [^coNmr  key  (the  CX]  key).  This 
menu  summarizes  all  conversion  menus  in  the  calculator.  The  list  of  these 
menus  is  shown  next: 


CORVERT  HERU 

i.uniTS..  1 

2.  RA£E.. 

3.  TRIG  CORV.. 
H.REHRITE.. 
E.HATRIK  COnVERT.. 

1         1         1  ICAnCLl 

OK 

The  functions  available  in  each  of  the  sub-menus  are  shov/n  next. 


UNITS  convert  menu  (Option  1 ) 

This  menu  is  the  same  as  the  UNITS  menu  obtained  by  using  [  J  units  .  The 
applications  of  this  menu  are  discussed  in  detail  in  Chapter  3. 
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BASE  convert  menu  (Option  2) 

This  menu  is  the  same  as  the  UNITS  menu  obtained  by  using  (j^l  base  .  The 
applications  of  this  menu  are  discussed  in  detail  in  Chapter  1 9. 

TRIGONOMETRIC  convert  menu  (Option  3) 

This  menu  is  the  same  as  the  TRIG  menu  obtained  by  using  trig  .  The 
applications  of  this  menu  are  discussed  in  detail  in  this  Chapter. 


MATRICES  convert  menu  (Option  5) 

This  menu  contains  the  following  functions: 


HHTRIX  COnVERT 

HEflU 

1  AMI. 

H.SYSTaMflT 
S.COnVERT.. 

HELP  1         1  1 

ICflnCLI 

OK 

These  functions  are  discussed  in  detail  in  Chapter  10. 


REWRITE  convert  menu  (Option  4) 
This  menu  contains  the  following  functions: 


REHRITE  HEnU 

l.DISTRIE  1 

a.EKF-Ln 
?.EKR2R0H 
H.FDISTRIE 
5.I-* 

e.Lin 

ICflnCL 

OK 

REHRITE  HEflU 


3. SIMPLIFY 

10.  -KlUM 

11.  -i 
ia.-t«n 
13 .  R-fl 


IH.COnVERT.. 


REHRITE  MERU 

?.LnCOLLECT  1 

S.POHEKPflRD 

S. SIMPLIFY 

10.  -KlUM 

11.  -i 

CflnCL  OK 


Functions  I^R  and  R^l  are  used  to  convert  a  number  from  integer  (I)  to  real 
(R),  or  vice  versa.  Integer  numbers  are  shown  without  trailing  decimal  points, 
while  real  numbers  representing  integers  will  have  a  trailing  decimal  point, 
e.g., 
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5. 

:R+I(12.) 

12 

Function  ^NUM  has  the  same  effect  as  the  keystroke  combination  Qf^:!^ 
(associated  with  the  [waj  key).  Function  ^NUM  converts  a  symbolic  result 
into  its  floating-point  value.    Function        converts  a  floating-point  value  into 
a  fraction.  Function  -^Qn  converts  a  floating-point  value  into  a  fraction  of  n, 
if  a  fraction  of  n  can  be  found  for  the  number;  otherwise,  it  converts  the 
number  to  a  fraction.    Examples  are  of  these  three  functions  are  shown  next. 


I -^0(2.  5533) 


,366025403735 


10000 


:-*QTr(.7536) 

3793 

5000 

: -^017(2. 09439510239) 

I- 

+^KIP|SKIP-H  H)EL 

DEL-f|DEL  LlinS" 

Out  of  the  functions  in  the  REWRITE  menu,  functions  DISTRIB,  EXPLN, 
EXP2POW,  FDISTRIB,  LIN,  LNCOLLECT,  POWEREXPAND,  and  SIMPLIFY 
apply  to  algebraic  expressions.  Many  of  these  functions  are  presented  in  this 
Chapter.  However,  for  the  sake  of  completeness  we  present  here  the  help- 
facility  entries  for  these  functions. 


DISTRIB 


jTSTRTF^ 
5tep/step  distribution 
*  and  ^  oyer  -Hand  - 
JlSTRIE<<X-i-V>*(:Z-i-l>> 

X*<Z-H)-i-Y*<Z-H) 

See:  FDISTRIB 


EXIT   ECHO   £EE1   £EE2   iZZ3  HHIH 


EXPLN 


EXPLH: 

Rewrites  transcendent 

functions  in  terms  of 

EXP  and  LH 

EXPLHc:COS<X)) 

C  EXP  C  i  *X  > -Hi  .^EXP  C  i  *X  >  X 

See:  SI NCOS  EXP2HYP 


EXIT   ECHO   f  EEl   £EE2   iZZ3  HHIH 


EXP2POW 


EXP2P0W: 

Rewrite  exp(a*Ln(b>> 
as  b-^a 

EXP2P0W<EXP<X*LH<Y>>> 


EHIT   ECHO   ZZZl   ZZZ2   ZZZ3  HHIH 


FDISTRIB 


FDISTRIB: 

Full  distribution  of 
and  ^  oyer  +  and  - 
FDISTRIB<<X-i-Y>*<Z-i-l>> 
Z*X-H*X-HZ*Y-H*M 

[See:  DISTRIB 


EHIT   ECHO   ZZZl   ZZZ2   ZZZ3  HHIH 
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LIN 

-inearizat ion  of 
exponent  ials 
_IHtEXP<X>-^2> 

5ee:   TEXPflHD  TLIH 


EXIT  I  ECHO  I  £EE1  |  £EE2  |  iZZ3  \  HHIH 


POWEREXPAND 
^OWEXPFlHD: 

5tep-^step  expansion  of 
lowers 

=OWEXPRHDt  tX+Y>-^2> 
5ee: 


EXIT  I  ECHO  I  £EE1  |  £EE2  |  iZZ3  \  HHIH 


LNCOLLECT 
LHCOLLECT: 
Collects  logarithms 
LHCOLLECTtLRtX>+LHtY>  > 
LHtX*Y> 


See:  TEXPRHD 


EHIT  I  ECHO  I  f  EEl  |  iZZ2  \  iZZ3  \  HHIH 


SIMPLIFY 

SIMPLIFY: 

Attempts  to  simplify 
an  expression 
SlMPLlFY<SlHt3XVSlHtX 

See:   EXPRHD  COLLECT 


EHIT  I  ECHO  I  f  EEl  |  iZZ2  \  iZZ3  \  HHIH 
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Chapter  6 

Solution  to  single  equations 

In  this  chapter  we  feature  those  functions  that  the  calculator  provides  for 
solving  single  equations  of  the  form  f(X)  =  0.   Associated  with  the  L7J  key 
there  are  two  menus  of  equation-solving  functions,  the  Symbolic  SOLVer 
{(^ssy_  ),  and  the  NUMerical  SoLVer  (C^numslv  ).  Following,  we  present 
some  of  the  functions  contained  in  these  menus.  Change  CAS  mode  to 
Complex  for  these  exercises  (see  Chapter  2). 


Symbolic  solution  of  algebraic  equations 

Here  we  describe  some  of  the  functions  from  the  Symbolic  Solver  menu. 
Activate  the  menu  by  using  the  keystroke  combination  .  With  system  flag  1 17 
set  to  CHOOSE  boxes,  the  following  menu  lists  will  be  available: 


2.I£0L 
?.LDEC 
H.LinSOLVE 
5.S0LVEVK 
e. SOLVE 


S 

SLV  HEnu 

2 

ISOL 

3 

LDEC 

H 

LinSOLVE 

5 

SOLVEVK 

SOLVE 

2ER0S 

HELP  1         1         1  ICHnCLl 

OH 

Functions  DESOLVE  and  LDEC  ore  used  for  the  solution  of  differential 
equations,  the  subject  of  a  different  chapter,  and  therefore  will  not  be 
presented  here.  Similarly,  function  LINSOLVE  relates  to  the  solution  of  multiple 
linear  equations,  and  it  will  be  presented  in  a  different  chapter.  Functions 
ISOL  and  SOLVE  can  be  used  to  solve  for  any  unknown  in  a  polynomial 
equation.  Function  SOLVEVX  solves  a  polynomial  equation  where  the 
unknown  is  the  default  CAS  variable  VX  (typically  set  to  'X').  Finally,  function 
ZEROS  provides  the  zeros,  or  roots,  of  a  polynomial.  Entries  for  all  the 
functions  in  the  S.SLV  menu,  except  ISOL,  are  available  through  the  CAS  help 
facility  (LroaJC^Iii[ 


Function  ISOL 

Function  ISOL(Equation,  variable)  will  produce  the  solution(s)  to  Equation  by 
isolating  variable.  For  example,  with  the  calculator  set  to  ALG  mode,  to  solve 
for  t  in  the  equation  at"^-bt  =  0  we  can  use  the  following: 
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:  ISod'a't'^-b't'vt'J 


+^KIP|SKIP^  H)EL  I  DEL-f|DEL  L|  inS  ■ 


Using  the  RPN  mode,  the  solution  is  accomplished  by  entering  the  equation  in 
the  stack,  followed  by  the  variable,  before  entering  function  ISOL.  Right 
before  the  execution  of  ISOL,  the  RPN  stack  should  look  as  in  the  figure  to  the 
left.  After  applying  ISOL,  the  result  is  shown  in  the  figure  to  the  right: 


+^KIP|SKIPH  H)EL  I  DEL-f|DEL  L|  inS  ■■^^TKIM^KIPH         |  DEL-» |DEL  L|  in£  ■! 


3: 


't ' 


The  first  argument  in  ISOL  can  be  an  expression,  as  shown  above,  or  an 
equation.  For  example,  in  ALG  mode,  try: 

ISOLlV.'^-k.^.=k'^',vJ 


I- 


[-l+-j5)-k  ,  _[l+-J5k 


CflSCMI  HELP 


Note:  To  type  the  equal  sign  (=)  in  an  equation,  use  I  r»  J  ^  (associated 

with  the  IjjzJ  key). 

The  same  problem  can  be  solved  in  RPN  mode  as  illustrated  below  (figures 
show  the  RPN  stack  before  and  after  the  application  of  function  ISOL): 


3: 


2  2 


CflSCM  HELP 


1=  J.  _  [-1+J5).k  .  _[1+J5)^ 

r"      2  2 


CflSCH  HELP 


Function  SOLVE 

Function  SOLVE  has  the  same  syntax  as  function  ISOL,  except  that  SOLVE  can 
also  be  used  to  solve  a  set  of  polynomial  equations.  The  help-facility  entry  for 
function  SOLVE,  with  the  solution  to  equation        -  1  =  3  ,  is  shown  next: 

SOLVE: 

Solves  a  (.or  a  set  of? 
polynomial  equation 
SOLVE  1=3  5.x  > 

CA=T2  X=-J"2J 

See:   LIHSOLVE  SOLVEVX 


EHIT  I  ECHO  I  f  EEl  |  £EE2  |  iZZ3  \  HHIH 
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The  following  examples  show  the  use  of  function  SOLVE  in  ALG  and  RPN 
modes: 


solve('p^-5-p=i25';p') 

S0LVE('p^-5-p=6';d_ 
[p=-l  p=2  p=-'^^^^  p=->' 


t^KIP  SKIP-H  H)EL   DEL-f  DEL  L  inS  i 


The  screen  shot  shown  above  displays  two  solutions.  In  the  first  one,  P'^-Sp 
=  1  25,  SOLVE  produces  no  solutions  { }.  In  the  second  one,  p"*  -  5p  =  6, 
SOLVE  produces  four  solutions,  shown  in  the  last  output  line.    The  very  last 
solution  is  not  visible  because  the  result  occupies  more  characters  than  the 
width  of  the  calculator's  screen.  However,  you  can  still  see  all  the  solutions  by 
using  the  down  arrow  key  ("sj?),  which  triggers  the  line  editor  (this  operation 
can  be  used  to  access  any  output  line  that  is  wider  than  the  calculator's 
screen): 


solve!  p-5>=6;p'J 

i+i-irr 

2 

Cp=-l,p=2,p=-ta  +  i*-J" 

11  V2j,p=-t  a-i*-ni  V 

2>> 


+^KIP  SKIP-H  H)EL   DEL-f  DEL  L  IDS  i 


[p=-l  P=2  p=-^^^^^  p=-^ 


The  corresponding  RPN  screens  for  these  two  examples,  before  and  after  the 
application  of  function  SOLVE,  are  shown  next: 


3: 
2: 

l: 

 'P' 

+^KIP|SKIP-t 

1  H)EL 

DEL-f|DEL  L|inS" 

2: 

pUfp 

l: 

+^KIP|SKIP-t 

1  H)EL 

DEL-f|DEL  L|inS" 

4: 
3: 
2: 
l: 

 a  3 

+^KIP|SKIPH  H)EL  1  DEL-f 

|DEL  L|in£> 

2: 

^"  {p=-l  p=2p=- 

l  +  i-HT  ^ 

 2  ■ 

+^KIP|SKIPH  H)EL  1  DEL-f 

DEL  L|in£> 

Use  of  the  down-arrow  key  C^^)  in  this  mode  will  launch  the  line  editor: 


4  'p=-r  'e=2'  •p=-(.(. 
l  +  i*-ni>x'2V  'p=-((l- 
i*-niV2V  > 


t^KIP  SKIP-H  H)EL   DEL-f  DEL  L  IDS  i 
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Function  SOLVEVX 

The  function  SOLVEVX  solves  on  equation  for  the  default  CAS  variable 
contained  in  the  reserved  variable  name  VX.  By  default,  this  variable  is  set  to 
'X'.  Examples,  using  the  ALG  mode  v/ith  VX  =  'X',  are  shov/n  belov/: 


:  SOLVEVxfx^- 

-a.X= 

b) 

:  SOLVEVx[x^- 

-^■X= 

20) 

X=2 

+^KIP|SKIP^  H)EL 

DEL-f 

DEL  L 

ins  ■ 

In  the  first  case  SOLVEVX  could  not  find  a  solution.  In  the  second  case, 
SOLVEVX  found  a  single  solution,  X  =  2. 


The  follov/ing  screens  shov/  the  RPN  stack  for  solving  the  tv/o  examples  shov/n 
above  (before  and  after  application  of  SOLVEVX): 


CflSCM  HELP 


The  equation  used  as  argument  for  function  SOLVEVX  must  be  reducible  to  a 
rational  expression.  For  example,  the  following  equation  will  not  processed 
by  SOLVEVX:  


iSOLVEVX(JXHr=JX  +  l) 
'Hot  reducible  to  a 


+^KIP  SKIP-H  *OZL   DEL-»  DEL  L  IDS  ■^■CHSCH  HELP 


A  SOLVEVX 
Error: 

Hot  reducible 
to  a  rational 
expression 


:SC  

"Hot  reducible  to  a  r. 


Function  ZEROS 

The  function  ZEROS  finds  the  solutions  of  a  polynomial  equation,  without 
showing  their  multiplicity.  The  function  requires  having  as  input  the 
expression  for  the  equation  and  the  name  of  the  variable  to  solve  for. 
Examples  in  ALG  mode  are  shown  next: 

:ZER0SU^=32,J 
[     2'i'Tr      4'1'Tr  fe'i'Tr 

l2.e   ^    2.e   ^  ^  2 


+^HIP|SKIP-H  H)EL  I  DEL-»|DEL  L|  IDS  ■ 


:  ZEROs(k 

{0  1 

l  +  i-j3 
2 

+^KIP|SKIpt 

H)EL  1  DEL-f 

DEL  L|inS> 

Page  6-4 


To  use  function  ZEROS  in  RPN  mode,  enter  first  thie  polynomial  expression, 
tfien  tfie  variable  to  solve  for,  and  tfien  function  ZEROS.   Tfie  follov/ing  screen 
sfiots  shiow  the  RPN  stack  before  and  after  the  application  of  ZEROS  to  the 
tv/o  examples  above: 


3: 
Z: 

l: 

  'k  ' 

+^KIP|SKIP-t 

DEL-f 

DEL  L|in£> 

3: 
Z: 

l: 

  'm' 

+^KIP|SKIP-t 

DEL-f 

DEL  L|in£> 

The  Symbolic  Solver  functions  presented  above  produce  solutions  to  rational 
equations  (mainly,  polynomial  equations).  If  the  equation  to  be  solved  for  has 
all  numerical  coefficients,  a  numerical  solution  is  possible  through  the  use  of 
the  Numerical  Solver  features  of  the  calculator. 


Numerical  solver  menu 

The  calculator  provides  a  very  powerful  environment  for  the  solution  of  single 
algebraic  or  transcendental  equations.   To  access  this  environment  we  start 
the  numerical  solver  (NUM.SLV)  by  using  [    )hVM.sLv .  This  produces  a  drop- 


diff  It.. 
3.S*lu<  poly.. 
H. Solus  lin  s])s.. 
5. Solus  financs.. 
S.HSLV 

Item  2.  Solve  diff  eq..  is  to  be  discussed  in  a  later  chapter  on  differential 
equations.  Item  4.  Solve  lin  sys..  will  be  discussed  in  a  later  Chapter  on 
matrices.  Item  6.  A/IS/. V  (Multiple  equation  SoLVer)  will  be  presented  in  the 
next  chapter.    Following,  we  present  applications  of  items  3.  Solve  poly..,  5. 
Solve  finance,  and  /.  Solve  equafion..,  in  that  order.  Appendix  1-A,  at  the 
end  of  Chapter  1,  contains  instructions  on  how  to  use  input  forms  with 
examples  for  the  numerical  solver  applications. 
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Notes: 

1 .  Whenever  you  solve  for  a  value  in  the  NUM.SLV  applications,  the  value 
solved  for  v/ill  be  placed  in  the  stack.  This  is  useful  if  you  need  to  keep  that 
value  available  for  other  operations. 

2.  There  will  be  one  or  more  variables  created  whenever  you  activate  some  of 
the  applications  in  the  NUM.SLV  menu. 


Polynomial  Equations 

Using  the  Solve  poly...  option  in  the  calculator's  SO/.VE  environment  you  can: 

(1)  find  the  solutions  to  a  polynomial  equation; 

(2)  obtain  the  coefficients  of  the  polynomial  having  a  number  of  given  roots; 

(3)  obtain  an  algebraic  expression  for  the  polynomial  as  a  function  of  X. 

Finding  the  solutions  to  a  polynomial  equation 

A  polynomial  equation  is  an  equation  of  the  form:  a„x"  +  a„.jx" '  +  ...+  OjX  + 
Oq  =  0.  The  fundamental  theorem  of  algebra  indicates  that  there  are  n 
solutions  to  any  polynomial  equation  of  order  n.  Some  of  the  solutions  could 
be  complex  numbers,  nevertheless.  As  an  example,  solve  the  equation:  Ss''  + 
2s3  -  s  +  1  =  0. 


We  want  to  place  the  coefficients  of  the  equation  in  a  vector  [a„,a„,,ai  Oq]. 
For  this  example,  let's  use  the  vector  [3,2,0,-1,1].  To  solve  for  this  polynomial 
equation  using  the  calculator,  try  the  following: 

CW]NUM.sLv  <^  <^  lEITi  Select  Solve  poly. . . 

SD(^CEC3  !CIDCS  !  C2J 

CED  !  QDC^CED  jCTDEHI  Enter  vector  of  coefficients 

Si33SlS  Solve  equation 


The  screen  will  show  the  solution  as  follows: 


SOLVE  fln  K'-n+..+fll  K+flD? 
Coefficient!  I  on  ..  al      ] : 
[3. ,2. ,0. ,-1. , 1.  ] 

Entif  mti  Of  preii  SOLVE 


SVME  SOLVE 
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Press  Qntek}  to  return  to  stock.  The  stock  will  show  the  following  results  in  ALG 
mode  (the  some  result  would  be  shown  in  RPN  mode): 

i^QQts:  [[.  432194S94623,  > 


+^KIP|SKIP^  H)EL  I  DEL-f|DEL  L|  inS  ■ 


To  see  all  the  solutions,  press  the  down-arrow  key  (^^)  to  trigger  the  line 
editor: 

Roots:  [(.  432194094623,  ► 
: Roots: 

[  (. .  432194S94623,-.3S9... 


+^KIP|SKIP-H  H)EL  I  DEL-f|DEL  L|  inS  ■ 


All  the  solutions  are  complex  numbers:  (0.432,-0.389),  (0.432,0.389),  (- 

0.766,  0.632),  (-0.766,  -0.632). 


Note:  Recall  that  complex  numbers  in  the  calculator  are  represented  as 
ordered  pairs,  with  the  first  number  in  the  pair  being  the  real  port,  and  the 
second  number,  the  imaginary  part.  For  example,  the  number  (0.432,-0.389), 
a  complex  number,  will  be  written  normally  as  0.432  -  0.389/,  where  /  is  the 
imaginary  unit,  i.e.,     =  -1 . 

Note:  The  fundamental  theorem  of  algebra  indicates  that  there  ore  n  solutions 
for  any  polynomial  equation  of  order  n.  There  is  another  theorem  of  algebra 
that  indicates  that  if  one  of  the  solutions  to  a  polynomial  equation  with  real 
coefficients  is  a  complex  number,  then  the  conjugate  of  that  number  is  also  a 
solution.  In  other  words,  complex  solutions  to  a  polynomial  equation  with  real 
coefficients  come  in  pairs.  That  means  that  polynomial  equations  with  real 
coefficients  of  odd  order  will  hove  at  least  one  real  solution. 


Generating  polynomial  coefficients  given  the  polynomial's  roots 

Suppose  you  wont  to  generate  the  polynomial  whose  roots  are  the  numbers 
[1,5,  -2,  4].  To  use  the  calculator  for  this  purpose,  follow  these  steps: 


rWjNUMSLV  E[3 


Select  Solve  poly... 

Enter  vector  of  roots 
Solve  for  coefficients 
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Press  (mS)  to  return  to  stack,  the  coefficients  will  be  shown  in  the  stack. 


^^SOLVE  fln  K'-n+..+fll  K+flD^^ 

■[1. ,-S. ,9. ,3S. ,-40. ]l 

[1. ,5. ,-2. ,4.  : 

1 

freii  SOLVE 

EDITI         1  1 

SVME  ISOLVE 

Press        to  trigger  the  line  editor  to  see  all  the  coefficients.  

Note:  If  you  want  to  get  o  polynomial  with  real  coefficients,  but  having 
complex  roots,  you  must  include  the  complex  roots  in  pairs  of  conjugate 
numbers.  To  illustrate  the  point,  generate  a  polynomial  having  the  roots  [1 
(1,2)  (1,-2)].  Verify  that  the  resulting  polynomial  has  only  real  coefficients. 
Also,  try  generating  a  polynomial  with  roots  [1  (1,2)  (-1,2)],  and  verify  that 
the  resulting  polynomial  will  have  complex  coefficients. 

Generating  an  algebraic  expression  for  the  polynomial 

You  can  use  the  calculator  to  generate  an  algebraic  expression  for  a 
polynomial  given  the  coefficients  or  the  roots  of  the  polynomial.  The  resulting 
expression  will  be  given  in  terms  of  the  default  CAS  variable  X.  (The 
examples  below  shows  how  you  can  replace  X  with  any  other  variable  by 
using  the  function  | .) 

To  generate  the  algebraic  expression  using  the  coefficients,  try  the  following 
example.  Assume  that  the  polynomial  coefficients  are  [1,5,-2,4].  Use  the 
following  keystrokes: 


rW)NUM.SLV  ^  ^  llllljJIll 

[enter] 


Select  Solve  poly... 
Enter  vector  of  coefficients 

Generate  symbolic  expression 
Return  to  stack. 


The  expression  thus  generated  is  shown  in  the  stack  as: 

'X'^3+5*X'^2+-2*X-i-4'. 
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To  generate  the  algebraic  expression  using  the  roots,  try  the  following 
example.  Assume  that  the  polynomial  roots  are  [1,3,-2,1].  Use  the  following 
keystrokes: 


Select  Solve  poly... 
Enter  vector  of  roots 


[cnter] 


\Z/  !i:ii!j!.LJ.ail 


Generate  symbolic  expression 
Return  to  stack. 


The  expression  thus  generated  is  shown  in  the  stack  as:'(X-l)*(X-3)*(X+2)*(X-l)'. 
To  expand  the  products,  you  can  use  the  EXPAND  command.  The  resulting 
expression  is:  'X'^4-i-3*X'^3+  -3*X'^2+1 1  *X-6'. 

A  different  approach  to  obtaining  an  expression  for  the  polynomial  is  to 
generate  the  coefficients  first,  then  generate  the  algebraic  expression  with  the 
coefficients  highlighted.  For  example,  for  this  case  try: 

(I^Nmsiy  <::^      iuTi  Select  Solve  poly. . . 

^^3? tjnj tj.  L_/_J 03  LJJ  E nter  vector  of  roots 


The  expression  thus  generated  is  shown  in  the  stack  as:  'X'^4+-3*X'^3+  - 
3*X^2+1 1  *X-i-6*X'^0'.  The  coefficients  are  listed  in  stack  level  2. 

Financial  calculations 

The  calculations  in  item  5.  Solve  finance.,  in  the  Numerical  Solver  [NUM.SLV) 
are  used  for  calculations  of  time  value  of  money  of  interest  in  the  discipline  of 
engineering  economics  and  other  financial  applications.  This  application  can 
also  be  started  by  using  the  keystroke  combination       (J] finance  (associated 
with  the  I  9  J  key).  Before  discussing  in  detail  the  operation  of  this  solving 
environment,  we  present  some  definitions  needed  to  understand  financial 
operations  in  the  calculator. 


B!!>:<iTgi 


Solve  for  coefficients 
Generate  symbolic  expression 
Return  to  stack. 
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Definitions 

Often,  to  develop  projects,  it  is  necessary  to  borrow  money  from  a  financial 
institution  or  from  public  funds.   Tfie  amount  of  money  borrowed  is  referred  to 
as  tfie  Present  Value  (PV).  This  money  is  to  be  repaid  tfirougfi  n  periods 
(typically  multiples  or  sub-multiples  of  a  month)  subject  to  an  annual  interest 
rate  of  l%YR.  The  number  of  periods  per  year  (P/YR)  is  an  integer  number  of 
periods  in  which  the  year  will  be  divided  for  the  purpose  of  repaying  the  loan 
money.  Typical  values  of  P/YR  are  1  2  (one  payment  per  month),  24 
(payment  twice  a  month),  or  52  (weekly  payments).    The  payment{PI\Al)  is 
the  amount  that  the  borrower  must  pay  to  the  lender  at  the  beginning  or  end 
of  each  of  the  n  periods  of  the  loan.   The  future  value  of  the  money  (FV)  is  the 
value  that  the  borrowed  amount  of  money  will  be  worth  at  the  end  of  n 
periods.     Typically  payment  occurs  at  the  end  of  each  period,  so  that  the 
borrower  starts  paying  at  the  end  of  the  first  period,  and  pays  the  same  fixed 
amount  at  the  end  of  the  second,  third,  etc.,  up  to  the  end  of  the  n-th  period. 

Example  1  -  Calculating  payment  on  a  loan 

If  $2  million  are  borrowed  at  an  annual  interest  rate  of  6.5%  to  be  repaid  in 
60  monthly  payments,  what  should  be  the  monthly  payment?  For  the  debt  to 
be  totally  repaid  in  60  months,  the  future  values  of  the  loan  should  be  zero. 
So,  for  the  purpose  of  using  the  financial  calculation  feature  of  the  calculator 
we  will  use  the  following  values:  n  =  60,  l%YR  =  6.5,  PV  =  2000000,  FV  = 
0,  P/YR  =12.  To  enter  the  data  and  solve  for  the  payment,  PMT,  use: 
[  <n  )FiNANa  Start  the  financial  calculation  input  form 

&0  SSmi  Enter  n  =  60 

rE..  5  113311  Enter  l%YR  =  6.5  % 

20003013  tm  Enter  PV  =  2,000,000  US$ 

Skip  PMT,  since  we  will  be  solving  for  it 
8  iESli  Enter  FV  =  0,  the  option  End  is  highlighted 

^  CD  EEI331I  Highlight  PMT  and  solve  for  it 

The  solution  screen  will  look  like  this: 


^»TIME  VALUE  OF 

MVnEV^M 

n:  60 

I^VR:  6.  5 

fV-  2000000.00 

PHT:  S^H«^ 

P'-VR:  12 

FV:  0.00 

End 

*r  SOLVE 

EDITI         1         1  lAHVRI^VLVE 
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The  screen  now  shows  the  value  of  PMT  as  -39,1  32.30,  i.e.,  the  borrower 
must  pay  the  lender  US  $  39,1  32.30  at  the  end  of  each  month  for  the  next 
60  months  to  repay  the  entire  amount.   The  reason  why  the  value  of  PMT 
turned  out  to  be  negative  is  because  the  calculator  is  looking  at  the  money 
amounts  from  the  point  of  view  of  the  borrower.  The  borrower  has  +  US  $ 
2,000,000.00  at  time  period  t  =  0,  then  he  starts  paying,  i.e.,  adding  -US  $ 
39132.30  attimes  t  =  1,  2,      60.  Att  =  60,  the  net  value  in  the  hands  of 
the  borrower  is  zero.    Now,  if  you  take  the  value  US  $  39,1  32.30  and 
multiply  it  by  the  60  payments,  the  total  paid  back  by  the  borrower  is  US  $ 
2,347,937.79.  Thus,  the  lender  makes  a  net  profit  of  $  347,937.79  in  the  5 
years  that  his  money  is  used  to  finance  the  borrower's  project. 

Example  2  -  Calculating  amortization  of  a  loan 

The  same  solution  to  the  problem  in  Example  1  can  be  found  by  pressing 
SEiiriiS,  which  is  stands  for  AMORTIZATION.  This  option  is  used  to  calculate 
how  much  of  the  loan  has  been  amortized  at  the  end  of  a  certain  number  of 
payments.    Suppose  that  we  use  24  periods  in  the  first  line  of  the 
amortization  screen,  i.e.,  I  2  ][  4  }  SSSB.  Then,  press  iEIilliSS.   You  will  get  the 
following  result:  ™™™™  ™™™™ 


24 

1  h  1  1  IIH  1  M 

-215963. 6S 

12767SS.57 

EDIT  1         1         1         1  S-fV  \  AHOR 

This  screen  is  interpreted  as  indicating  that  after  24  months  of  paying  back 
the  debt,  the  borrower  has  paid  up  US  $  723,21 1 .43  into  the  principal 
amount  borrowed,  and  US  $  215,963.68  of  interest.   The  borrower  still  has 
to  pay  a  balance  of  US  $1,276,788.57  in  the  next  36  months. 

Check  what  happens  if  you  replace  60  in  the  Payments:  entry  in  the 
amortization  screen,  then  press  IIElffi  IlilHili.   The  screen  now  looks  like  this: 


efiMDRTIZE^^^« 

60 

B0151515151515M515M 

-347937.79 

-3. 16E-6 

EDIT  1         1         1         1  S-fV  \  AHDR 
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This  means  that  at  the  end  of  60  months  the  US  $  2,000,000.00  principal 
amount  has  been  paid,  together  with  US  $  347,937.79  of  interest,  with  the 
balance  being  that  the  lender  owes  the  borrower  US  $  0.000316.  Of 
course,  the  balance  should  be  zero.  The  value  shown  in  the  screen  above  is 
simply  round-off  error  resulting  from  the  numerical  solution. 

Press  L  OA/  J  or  [inter)  ,  twice,  to  return  to  normal  calculator  display. 

Example  3  -  Calculating  payment  with  payments  at  beginning  of  period 

Let's  solve  the  same  problem  as  in  Examples  1  and  2,  but  using  the  option 
that  payment  occurs  at  the  beginning  of  the  payment  period.  Use: 

I Jn^l  fiNANCE  Start  the  financial  calculation  input  form 

60  Eil]:lill  Enter  n  =  60 

6.5  113:38  Enter  l%YR  =  6.5  % 

2880800  S3IBI  Enter  PV  =  2,000,000  US$ 

Skip  PMT,  since  we  will  be  solving  for  it 

8  Mill  Enter  FV  =  0,  the  option  End  is  highlighted 

■EBEIEEilli^^  JEISS  Change  payment  option  to  Begin 

CD  !bEB3jI  Highlight  PMT  and  solve  for  it 

The  screen  now  shows  the  value  of  PMT  as  -38,921 .47,  i.e.,  the  borrower 
must  pay  the  lender  US  $  38,921 .48  at  the  beginning  of  each  month  for  the 
next  60  months  to  repay  the  entire  amount.    Notice  that  the  amount  the 
borrower  pays  monthly,  if  paying  at  the  beginning  of  each  payment  period,  is 
slightly  smaller  than  that  paid  at  the  end  of  each  payment  period.  The  reason 
for  that  difference  is  that  the  lender  gets  interest  earnings  from  the  payments 
from  the  beginning  of  the  period,  thus  alleviating  the  burden  on  the  lender. 

Notes: 

1 .  The  financial  calculator  environment  allows  you  to  solve  for  any  of  the 
terms  involved,  i.e.,  n,  l%YR,  PV,  FV,  P/Y,  given  the  remaining  terms  in  the 
loan  calculation.   Just  highlight  the  value  you  want  to  solve  for,  and  press 
SEEHEIil.   The  result  will  be  shown  in  the  highlighted  field. 
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2.  The  values  calculated  in  the  financial  calculator  environment  are  copied  to 
the  stack  v/ith  their  corresponding  tag  (identifying  label). 

Deleting  the  variables 

When  you  use  the  financial  calculator  environment  for  the  first  time  within  the 
HOME  directory,  or  any  sub-directory,  it  v/ill  generate  the  variables  11111111 
EMM  eMm  mMM  M^m  to  store  the  corresponding  terms  in  the  calculations.. 
You  can  see  the  contents  of  these  variables  by  using: 


L     JiBHij!!!  I     jE.a5.BjS!  L     jmrnm  (.     jmMium  [  r*  Jmjum  I  Jimijb. 

You  can  either  keep  these  variables  for  future  use,  or  use  the  PURGE  function 
to  erase  them  from  your  directory.  To  erase  all  of  the  variables  at  once,  if 
using  ALG  mode,  try  the  following: 

(WUCEEiajil  [W]    Enter  PURGE,  prepare  list  of  variables 

CZDCS  Enter  name  of  variable  N 

CD  [  r'  J  ;  Enter  a  comma 

CD  CSIlflia  Enter  name  of  variable  l%YR 

CD  Cj3  ;  Enter  a  comma 

L  ■  J  LitJ Enter  name  of  variable  PV 

CD  I    J  J  Enter  a  comma 

L  ■  J  [  r»  jSuCES  Enter  name  of  variable  PMT 

CD  CS  !  Enter  a  comma 

L  ■  J  LiiJ PiijilLiI jI!  Enter  name  of  variable  PYR 

CD  (jfJ  ;  Enter  a  comma 

L  ■  J  [  r»  jSulBil.  Enter  name  of  variable  FV 

[INTER]  Execute  PURGE  command 

The  following  two  screen  shots  show  the  PURGE  command  for  purging  all  the 
variables  in  the  directory,  and  the  result  after  executing  the  command. 


=URGEa  'H' , '  i::VR' , 

' PV ' , ' PMT ' , ' PYR ' , 
'FV 

:PURGE({'H'  'I\YR'  'PV  'PMT> 
 HOVRL 

+^KIP|SKIPH  H)EL  1  DEL-f|DEL  L|  inS  ■ 

+^KIP|SKIP-H  H)EL  1  DEL-f|DEL  L|  inS  ■ 

In  RPN  mode,  the  command  is  executed  by  using: 
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irTiw 
■IjHI 

(.7-oaJi[ 


Prepare  a  list  of  variables  to  be  purged 

Enter  name  of  variable  N 

Enter  name  of  variable  l%YR 

Enter  name  of  variable  PV 

Enter  name  of  variable  PMT 

Enter  name  of  variable  PYR 

Enter  name  of  variable  FV 

Enter  list  of  variables  in  stack 

Purge  variables  in  list 


Before  tfie  command  PURGE  is  entered,  the  RPN  stack  w\\\  look  like  tfiis: 


Solving  equations  with  one  unknown  through  NUM.SLV 

Tfie  calculator's  NUM.SLV  menu  provides  item  J.  Solve  equation.,  solve 
different  types  of  equations  in  a  single  variable,  including  non-linear  algebraic 
and  transcendental  equations.       For  example,  let's  solve  tfie  equation:  e"- 

sin{7tx/3}  =  0. 

Simply  enter  tfie  expression  as  an  algebraic  object  and  store  it  into  variable 
EQ.  The  required  keystrokes  in  ALG  mode  are  the  following: 

CD      ^— (2  CE' CZD  C«D 

(TtoT)  [alfha]  (T\  [umA]  (svth) 


Function  STEQ 

Function  STEQ,  available  through  the  command  catalog,  (.  r»  J  cat^  ,  will  store 
its  argument  into  variable  EQ,  e.g.,  in  ALG  mode: 


STEQ[e^-SIH[^]=0 


HOVRL 


In  RPN  mode,  enter  the  equation  between  apostrophes  and  activate  command 
STEQ.  Thus,  function  STEQ  can  be  used  as  a  shortcut  to  store  an  expression 
into  variable  EQ. 
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Press  (.  VAR  J  to  see  the  newly  created  EQ  variable 


'e^-SIH[^]=0VEQ 


0 


Then,  enter  the  SOLVE  environment  and  select  Solve  equation...,  by  using: 
[  i->  jMMSLv  E3I.  The  corresponding  screen  will  be  shown  as: 

SOLVE  E4UflTI0n^^™ 


The  equation  we  stored  in  variable  EQ  is  already  loaded  in  the  Eq  field  in  the 
SOLVE  EQUATION  input  form.  Also,  a  field  labeled  x  is  provided.    To  solve 
the  equation  all  you  need  to  do  is  highlight  the  field  in  front  of  X:  by  using 
and  press  IIEI-EiiS.  The  solution  shown  is  X:  4.5006E-2: 


SOLVE  ECUHTIOn 

Eq :  EXP  <  X )  -S I H  <  Tr*x^3 )  =0 


4.500613S5902E-2 


Zntir  00  Im  *r  fciii  SOLVE 


VHRS  inro  SOLVE 


This,  however,  is  not  the  only  possible  solution  for  this  equation.  To  obtain  a 
negative  solution,  for  example,  enter  a  negative  number  in  the  X:  field  before 
solving  the  equation.  Try  [3  jS^SSKryBSSIS.  The  solution  is  now  X:  - 
3.045. 

Solution  procedure  for  Equation  Solve... 

The  numerical  solver  for  single-unknown  equations  works  as  follows: 

•  It  lets  the  user  type  in  or  HIJluB  an  equation  to  solve. 

•  It  creates  an  input  form  with  input  fields  corresponding  to  all  variables 
involved  in  equation  stored  in  variable  EQ. 

•  The  user  needs  to  enter  values  for  all  variables  involved,  except  one. 
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•  The  user  then  highlights  the  field  corresponding  to  the  unknown  for 
which  to  solve  the  equation,  and  presses  H^IOEEi 

•  The  user  may  force  a  solution  by  providing  an  initial  guess  for  the 
solution  in  the  appropriate  input  field  before  solving  the  equation. 

The  calculator  uses  a  search  algorithm  to  pinpoint  an  interval  for  which  the 
function  changes  sign,  which  indicates  the  existence  of  a  root  or  solution.  It 
then  utilizes  a  numerical  method  to  converge  into  the  solution. 

The  solution  the  calculator  seeks  is  determined  by  the  initial  value  present  in 
the  unknown  input  field.  If  no  value  is  present,  the  calculator  uses  a  default 
value  of  zero.  Thus,  you  can  search  for  more  than  one  solution  to  an 
equation  by  changing  the  initial  value  in  the  unknown  input  field.  Examples 
of  the  equations  solutions  are  shown  following. 

Example  1  -  Hooke's  law  for  stress  and  strain 

The  equation  to  use  is  Hooke's  law  for  the  normal  strain  in  the  x-direction  for  a 
solid  particle  subjected  to  a  state  of  stress  given  by 


cr 

cr 

cr 

The  equation  is      =  — [cr^  —  n  •  {cr   +  cr^)]  +  a  •  AT,  here      is  the  unit 
E 

strain  in  the  x-direction,  a^^,  ayy,  and  cr^^,  are  the  normal  stresses  on  the 
particle  in  the  directions  of  the  x-,  y-,  and  z-axes,  E  is  Young's  modulus  or 
modulus  of  elasticity  of  the  material,  n  is  the  Poisson  ratio  of  the  material,  a  is 
the  thermal  expansion  coefficient  of  the  material,  and  AT\s  a  temperature 
increase. 


Suppose  that  you  are  given  the  following  data:  a^^=  2500  psi,  (Tyy  =  ^  200  psi, 
and  oi,  =  500  psi,  E  =  1200000  psi,  n  =  0.15,  a  =  0.0000 1/°F,  AT  =  60  °F. 
To  calculate  the  strain  e^^  use  the  following: 

{j^]NUM.sLv  lESSi  Access  numerical  solver  to  solve  equations 

Ir* )  i<2w  Access  the  equation  writer  to  enter  equation 
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At  this  point  follow  the  instructions  from  Chapter  2  on  how  to  use  the  Equation 
Writer  to  build  an  equation.  The  equation  to  enter  in  the  Eq  field  should  look 
like  this  (notice  that  we  use  only  one  sub-index  to  refer  to  the  variables,  i.e., 
e^  is  translated  as  ex,  etc.  -  this  is  done  to  save  typing  time): 


?X=p'((TX-rTC(Ty+(Tz))+OC^T 


EDIT  I  CUR£  I  EIG  ■!  EVHL  |FHCTO|  £IHP 


Use  the  following  shortcuts  for  special  characters: 

ct:       (^^CgDO       a:       (^^CE3(3       A:  (4^^(153(3 


and  recall  that  lower-case  letters  are  entered  by  using  lAumji  <n  j  before  the 
letter  key,  thus,  x  is  typed  as  (4t™)C5D(3  • 

Press  [INTER)  to  return  to  the  solver  screen.  Enter  the  values  proposed  above  into 
the  corresponding  fields,  so  that  the  solver  screen  looks  like  this: 


SOLVE  ECUHTIOn: 

Eq :  ex=l -^E*  <  (jx-n*  <  (Ty-i-(T„, 
<y.-  E:  120...  25... 

n:  .15     'n-   12...  500 

.00...    ^T:  60 

Zntic  uolm  *r  prm  SOLVE 


With  the  ex:  field  highlighted,  press 


to  solve  for  ex: 


SOLVE  ECUHTIOn 

Eq :  ex=l -^E*  <  (Jx-n*  <  (Ty-i-(T„, 
<y.-  Mi  E:  120...  m:  25... 
n:  .15     'n-   12...  500 

.00...    ^T:  60 
Enttr  ojlm  or  prgjj  SOLVE  


vflRS  inro  SOLVE 
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The  solution  con  be  seen  from  within  the  SOLVE  EQUATION  input  form  by 
pressing  Lijui  while  the  ex;  field  is  highlighted.  The  resulting  value  is 
2.470833333333E-3.  Press  BI3!  to  exit  the  EDIT  feature. 

Suppose  that  you  now,  want  to  determine  the  Young's  modulus  that  will 
produce  a  strain  of  e^^  =  0.005  under  the  same  state  of  stress,  neglecting 
thermal  expansion.  In  this  case,  you  should  enter  a  value  of  0.005  in  the  ex: 
field,  and  a  zero  in  the  AT:  field  (with  AT  =  0,  no  thermal  effects  are 
included).  To  solve  for  E,  highlight  the  E:  field  and  press  The  result, 

seeing  with  the  Oliil  feature  is,  E  =  449000  psi.  Press  lE^il^iiH  (mh)  to  return 
to  normal  display. 

Notice  that  the  results  of  the  calculations  performed  within  the  numerical 
solver  environment  have  been  copied  to  the  stack: 


ex:2.470S3333333E-3 
E: 449000. 


Also,  you  will  see  in  your  soft-menu  key  labels  variables  corresponding  to 
those  variables  in  the  equation  stored  in  EQ  (press  I^xtJ  to  see  all  variables  in 
your  directory),  i.e.,  variables  ex,  AT,  a,  az,  ay,  n,  ox,  and  E. 

Example  2  -  Specific  energy  in  open  channel  flow 

Specific  energy  in  an  open  channel  is  defined  as  the  energy  per  unit  weight 
measured  with  respect  to  the  channel  bottom.  Let  E  =  specific  energy,  y  = 
channel  depth,  V  =  flow  velocity,  g  =  acceleration  of  gravity,  then  we  write 

E  =  y  +  . 

2g 

The  flow  velocity,  in  turn,  is  given  by  V  =  Q/A,  where  Q  =  water  discharge, 
A  =  cross-sectional  area.   The  area  depends  on  the  cross-section  used,  for 
example,  for  a  trapezoidal  cross-section,  as  shown  in  the  figure  below,  A  = 
(b-Hm  y)  y,  where  b  =  bottom  width,  and  m  =  side  slope  of  cross  section. 


Page  6-1 8 


We  can  type  in  the  equation  for  E  as  shown  above  and  use  auxiliary 
variables  for  A  and  V,  so  that  the  resulting  input  form  will  have  fields  for  the 
fundamental  variables  y,  Q,  g,  m,  and  b,  as  follows: 

•     First,  create  a  sub-directory  called  SPEN  (SPecific  ENergy)  and  work 
within  that  sub-directory. 
Next,  define  the  following  variables: 


Q 
R 

R 

2' 

:  E=y-i-^  ►EQ 

Launch  the  numerical  solver  for  solving  equations:  Ij^]num.slv  I 
Notice  that  the  input  form  contains  entries  for  the  variables  y,  Q,  b,  m, 
and  g: 


SOLVE  ECUHTIOn^ 


3- 

Zntic  function 


EDIT  CHOO£ 


Try  the  following  input  data:  E  =  1 0  ft,  Q  =  1 0  cfs  (cubic  feet  per 
second),  b  =  2.5  ft,  m  =  1 .0,  g  =  32.2  ft/s^- 


3(!lVl  ECUHTIOn 

Eq:E=yH-V-^£^t£*a2 

E:  10  3 
f-  10  b 
h:    1  3 

Enttr  ujlm  or  prgjj  SOLVE 


Solve  for  y. 
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£OLVE  ECUHTIOn 

E:  10  y 
6:  10  b 
h:    1  3 


.  149S36... 


2.5 
32.2 


Enttr  ujlm  or  prgjj  SOLVE 


vflRS  inro  SOLVE 


The  result  is  0.149836..,  i.e.,  y  =  0.149836. 
It  is  known,  however,  that  there  ore  actually  two  solutions  available 
for  y  in  the  specific  energy  equation.  The  solution  we  just  found 
corresponds  to  a  numerical  solution  with  on  initial  value  of  0  (the 
default  value  for  y,  i.e.,  whenever  the  solution  field  is  empty,  the 
initial  value  is  zero).  To  find  the  other  solution,  we  need  to  enter  a 
larger  value  of  y,  say  1.5,  highlight  the  y  input  field  and  solve  for  y 
once  more: 


SOLVE  ECUHTIOn 

Eq:E=y+V-^2/C2*a2 

E:    10  y 
4:    10  b:  2.5 

H:    1  3:  32.2 


9.99990... 


Entif  UJlm  Of  pfjff  SOLVE 

The  result  is  now  9.99990,  i.e.,  y  =  9.99990  ft. 


This  example  illustrates  the  use  of  auxiliary  variables  to  write  complicated 
equations.  When  NUM.SLV  is  activated,  the  substitutions  implied  by  the 
auxiliary  variables  are  implemented,  and  the  input  screen  for  the  equation 
provides  input  field  for  the  primitive  or  fundamental  variables  resulting  from 
the  substitutions.  The  example  also  illustrates  an  equation  that  has  more  than 
one  solution,  and  how  choosing  the  initial  guess  for  the  solution  may  produce 
those  different  solutions. 


In  the  next  example  we  will  use  the  DARCY  function  for  finding  friction  factors 
in  pipelines.  Thus,  we  define  the  function  in  the  following  frame. 

Special  function  for  pipe  flow:  DARCY  (8/D,Re) 

The  Darcy-Weisbach  equation  is  used  to  calculate  the  energy  loss  (per  unit 
weight),  hf,  in  a  pipe  flow  through  a  pipe  of  diameter  D,  absolute  roughness 
E,  and  length  L,  when  the  flow  velocity  in  the  pipe  is  V.    The  equation  is 
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L 

written  as  hf  =  f  .  The  quantity  f  \s  known  as  the  friction  factor  of 

^         D  2g 

the  flow  and  it  has  been  found  to  be  a  function  of  the  relative  roughness  of  the 
pipe,  s/D,  and  a  (dimensionless)  Reynolds  number.  Re.  The  Reynolds  number 
is  defined  as  Re  =  pVD/jj,  =  VD/v,  where  p  and  are  the  density  and 
dynamic  viscosity  of  the  fluid,  respectively,  and  v  =  (x/p  is  the  kinematic 
viscosity  of  the  fluid. 

The  calculator  provides  a  function  called  DARCY  that  uses  as  input  the  relative 
roughness  s/D  and  the  Reynolds  number,  in  that  order,  to  calculate  the  friction 


CHTALOG:  757  COHHAnD^ 

DARCY  11 

DATE 

DATE+ 

DDUG 

DDAY£ 

DEC 

1       1       1  IcflncL 

OK 

For  example,  for  e/D  =  0.0001,  Re  =  1000000,  you  can  find  the  friction 
factor  by  using:  DARCY(0. 000 1,1 000000).  In  the  following  screen,  the 
function  ^NUM  ()  was  used  to  obtain  a  numerical  va  ue  of  the  function: 


DflRCYt.  000 1.1 0000005 

DRRCYt.  0001,1000000) 
■^HUMtRHStD) 

1.34414320724E-2 


The  result  is  f  =  DARCY(0.000 1,1 000000)  =  0.01 341 . 


The  function  FANNING(E/D,Re) 

In  aerodynamics  applications  a  different  friction  factor,  the  Fanning  friction 
factor,  is  used.  The  Fanning  friction  factor,  ^p,  is  defined  as  4  times  the  Darcy- 
Weisbach  friction  factor,  f.  The  calculator  also  provides  a  function  called 
FANNING  that  uses  the  same  input  as  DARCY,  i.e.,  e/D  and  Re,  and 
provides  the  FANNING  friction  factor.   Check  that 
FANNING(0.0001, 1000000)  =  0.0033603589181s. 
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DRRCVt.  0001,1000000)1 
i-*HUM(RHS(l)) 

1.34414320724E-2 
1  FflHH  I  HGt .  000 1 , 1 000000) 
FRHHIHGt.  0001,1000000) 
i-*HUM(RHS(l)) 

3.36035S01S1E-3 


Example  3  -  Flow  in  a  pipe 

You  may  want  to  create  a  separate  sub-directory  (PIPES)  to  try  this  example. 
The  main  equation  governing  flow  in  a  pipe  is,  of  course,  the  Darcy-Weisbach 
equation.  Thus,  type  in  the  following  equation  into  EQ: 


hf  = 


2 


Also,  enter  the  following  variables  (f,  A,  V,  Re): 


hif  = 


DRRCY 


DRRCY[^,Re 


4 

Q 

R 

i       1  II        1  1^  ^  ji  ^■_  j 

 4 

Q 

R 

Hu 

In  this  case  we  stored  the  main  equation  (Darcy-Weisbach  equation)  into  EQ, 
and  then  replaced  several  of  its  variables  by  other  expressions  through  the 
definition  of  variables  f,  A,  V,  and  Re.  To  see  the  combined  equation,  use 
EVAL(EQ).  In  this  example  we  changed  the  display  setting  so  that  we  can  see 
the  entire  equation  in  the  screen: 


EVHL(EC) 


S.4  .L.DflRCV 


6  H 


nu 
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Thus,  the  equation  we  are  solving,  after  combining  the  different  variables  in 
the  directory,  is: 

^      QD  ^ 

^2  ; 


h.=  ^9_L.DARCY 


D'  Nu 


The  combined  equation  has  primitive  variables:  hf,  Q,  L,  g,  D,  s,  and  Nu. 
Launch  the  numerical  solver  ([  jaww  jEEB)  to  see  the  primitive  variables 
listed  in  the  SOLVE  EQUATION  input  form: 


hf:                 e:  D: 

t:  nu:  L: 
3: 

En't<r  function  f*lu< 


EDIT 


Suppose  that  we  use  the  values  hf  =  2  m,  e  =  0.00001  m,  Q  =  0.05  mVs, 
Nu  =  0.000001  mVs,  L  =  20  m,  and  g  =  9.806  m/s^  find  the  diameter  D. 
Enter  the  input  values,  and  solve  for  D,  The  solution  is;  0. 1 2,  i.e.,  D  =  0. 1 2 
m. 


SOLVE  ECUHTIOnS 

Eq:  hif  =f  *V-^£*L.^<£*9*D) 

hf:     2  e:    .00...    D:  UBI 

.05       nu:     .0,,,    L:  £0 

3:  9.3... 

Enttr  ujlut  or  prgjj  SOLVE  


vflRS  inro  SOLVE 


If  the  equation  is  dimensionally  consistent,  you  can  add  units  to  the  input 
values,  as  shown  in  the  figure  below.  However,  you  must  add  those  units  to 
the  initial  guess  in  the  solution.  Thus,  in  the  example  below  we  place  0_m  in 
the  D:  field  before  solving  the  problem.  The  solution  is  shown  in  the  screen  to 
the  right: 


^ SOLVE  ECUHTIOn; 

Eq:  hf  =f  *V-^£*L.^<2*9*D) 
hf:    2_m   e:   .00...   D:  eHM 

.5_...    nu:     .0,,,    L:  10_m 

3:  9.3... 

Enter  oolu«  *r  prejf  SOLVE 


VHRS   inrO  SOLVE 


m 

^»SOLVE  E4UflTI0nS 

Eq 

hf 

Z-V\    e:    .00...  0: 

wm 

t: 

.5_...    nu:     .0,,,  L: 

10_m 

3: 

9.3... 

1 

25921043969S_m ' 

Press  [fwrasj  to  return  to  normal  calculator  display.  The  solution  for  D  will  be 
listed  in  the  stack. 
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Example  4  -  Universal  gravitation 

Newton's  law  of  universal  gravitation  indicates  that  the  magnitude  of  the 

attractive  force  between  two  bodies  of  masses  m,  and       separated  by  a 

,.  .    .      ,     ,  .  ^  M,  •  M, 

distance  r  is  given  by  the  equation  r  =  Lr  ^  . 

r 

Here,  G  is  the  universal  gravitational  constant,  whose  value  can  be  obtained 
through  the  use  of  the  function  CONST  in  the  calculator  by  using: 


:  COHST(G) 

6.67259E-11 

3 

m 

s  'kg 

We  can  solve  for  any  term  in  the  equation  (except  G)  by  entering  the 
equation  as: 


This  equation  is  then  stored  in  EQ: 


6.67259E-11_- 


2, 

F=COHSTtG>^^^^^^frEQ 


Launching  the  numerical  solver  for  this  equation  results  in  an  input  form 
containing  input  fields  for  F,  G,  ml,  m2,  and  r. 


F=<6.67259E-ll_m-"3„, 


H2: 


Entsr  function  alvs 


EDIT  CHOOS 


Let's  solve  this  problem  using  units  with  the  following  values  for  the  known 
variables  ml  =  1 .0x1 0"^ kg,  m2  =  1 .0x1 0^^ ^g,  r  =  1 .0x1 0^^  m.  Also,  enter 
a  value  of  0_N  in  field  F  to  ensure  the  proper  solution  using  units  in  the 
calculator: 
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£OLVE  ECUHTIOn 

Eq :  F=<:6.67259E- 1 1  .m-^S,,, 

F:  [MI^^H  H2:  l.E12_... 
Ml:     100000,,,   r:  1000000,,, 

Enttr  ujlm  or  prgjj  SOLVE 


Solve  for  F,  and  press  to  return  to  normal  calculator  display.  The  solution  is  F  : 
6.67259E-15_N,  or  F  =  6.67259x10-^5  N. 

Note:  When  using  units  in  the  numerical  solver  make  sure  that  all  the 
variables  have  the  proper  units,  that  the  units  are  compatible,  and  that  the 
equation  is  dimensionally  homogeneous. 


Different  ways  to  enter  equations  into  EQ 

In  all  the  examples  shown  above  we  have  entered  the  equation  to  be  solved 
directly  into  variable  EQ  before  activating  the  numerical  solver.  You  can 
actually  type  the  equation  to  be  solved  directly  into  the  solver  after  activating 
it  by  editing  the  contents  of  the  EQ  field  in  the  numerical  solver  input  form.  If 
variable  EQ  has  not  been  defined  previously,  when  you  launch  the  numerical 
solver  (l^mm  S3SI),  the  EQ  field  will  be  highlighted: 


» SOLVE 

E4UflTI0n^^« 

Entif 

function 

EDIT 

CHOOSI 

IVHRSI  |EXPR= 

At  this  point  you  can  either  type  a  new  equation  by  pressing You  wil 
be  provided  with  a  set  of  apostrophes  so  that  you  con  type  the  expression 
between  them: 


'4 


Type  an  equation,  say        ■  1 25  =  0,  directly  on  the  stack,  and  press  ilii 
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=0 

Enter  uolu«  *r 

prjff  SOLVE 

At  this  point  the  equation  is  ready  for  solution 


Alternatively,  you  con  activate  the  equation  v/riter  after  pressing  Haii  to  enter 
your  equation.  Press  Iwaj  to  return  to  the  numerical  solver  screen. 

Another  way  to  enter  an  equation  into  the  EQ  variable  is  to  select  a  variable 
already  existing  in  your  directory  to  be  entered  into  EQ.  This  means  that  your 
equation  v/ould  have  to  have  been  stored  in  a  variable  name  previously  to 
activating  the  numerical  solver.  For  example,  suppose  that  we  have  entered 
the  following  equations  into  variables  EQl  and  EQ2: 


X  -5S=0tEQl 

2 


X^-5S=0| 


a  -a+300=0frEQ2 

 a  -a+30^=0 


LSTS  CHflni  POLRfl 


Now,  launch  the  numerical  solver  ([  r>  JMj>«wiElig,  and  highlight  the  EQ  field. 

At  this  point  press  the ""i  soft  menu  key.  Use  the  up  and  down  arrow  keys 
)  to  select,  say,  variable  EQl : 


Press  ::'::T::°::°  after  selecting  EQl  to  load  into  variable  EQ  in  the  solver.  The 
new  equation  is  ready  to  be  solved. 


SOLVE  ECUHTIOn 
Eq:X-^3.-5S.=0. 


Ent«r  ualui  *r  pr«ff  SOLVE 
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The  SOLVE  soft  menu 

The  SOLVE  soft  menu  allows  access  to  some  of  the  numerical  solver  functions 
through  the  soft  menu  keys.  To  access  this  menu  use  in  RPN  mode;  74 
MENU,  or  in  ALG  mode:  MENU(74).  Alternatively,  you  can  use  [13  (hold) 
I  7  J  to  activate  the  SOLVE  soft  menu.   The  sub-menus  provided  by  the  SOLVE 
soft  menu  are  the  follov/in^^  


ROOT  DIFFE  POLV  SVS 


The  ROOT  sub-menu 

The  ROOT  sub-menu  include  the  following  functions  and  sub-menus: 


SOLVR  ROOT 


Function  ROOT 

Function  ROOT  is  used  to  solve  an  equation  for  a  given  variable  with  a 
starting  guess  value.  In  RPN  mode  the  equation  will  be  in  stack  level  3,  while 
the  variable  name  will  be  located  in  level  2,  and  the  initial  guess  in  level  1 . 
The  following  figure  shows  the  RPN  stack  before  and  after  activating  function 


4: 

3: 

TRH(e)=e 

Z: 

'9  ' 

l: 

5 

£OLVR|ROOT|  EC 

1  I^OLVE 

4: 
l: 


SOLVR  ROOT 


7.725251S3694 


In  ALG  mode,  you  would  use  ROOT('TAN(e)=0','e',5)  to  activate  function 
ROOT: 


ROOT('TRH(e)=e' '9' 5) 

7.72525133694 


SOLVR  ROOT 


Varioble  EQ 

The  soft  menu  key  SH^II  in  this  sub-menu  is  used  as  a  reference  to  the  variable 
EQ.  Pressing  this  soft  menu  key  is  equivalent  to  using  function  RCEQ  (ReCali 
EQ). 
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The  SOLVR  sub-menu 

The  SOLVR  sub-menu  activates  the  soft-menu  solver  for  the  equation  currently 
stored  in  EQ.  Some  examples  are  shov/n  next: 

Example  1  -  Solving  the  equation  t^-5t  =  -4 

For  example,  if  you  store  the  equation  't'^2-5*t=-4'  into  EQ,  and  press  EMjJSIi], 
it  v/ill  activate  the  followinp  menu:  

r't  ii'fjg  I — I 

This  result  indicates  that  you  can  solve  for  a  value  of  t  for  the  equation  listed  at 
the  top  of  the  display.  If  you  try,  for  example,  ijjj  [    t   ],  it  will  give  you  the 
result  t:  1 .,  after  briefly  flashing  the  message  "Solving  for  t."  There  is  a 
second  root  to  this  equation,  which  can  be  found  by  changing  the  value  of  t, 
before  solving  for  it  again.  Do  the  following:  1 0  [   t   ],  then  press  UiJ  [  t  ]. 
The  result  is  now,  t:  4.0000000003.  To  verify  this  result,  press  the  soft  menu 
key  labeled  1111101,  which  evaluates  the  expression  in  EQ  for  the  current  value 
of  t.  The  results  in  this  case  are: 


J- 

4: 

t:  1. 

3: 

t: 4. 00000000003 

Z: 

Left:  (-4.) 

l: 

Right:  (-4) 

-L. 

 II 

To  exit  the  SOLVR  environment,  press  .  The  access  to  the  SOLVE  menu  is 
lost  at  this  point,  so  you  have  to  activate  it  once  more  as  indicated  earlier,  to 
continue  with  the  exercises  below. 

Example  2  -  Solving  the  equation  Q  =  at^+bt 

It  is  possible  to  store  in  EQ,  an  equation  involving  more  than  one  variable, 

say,  'Q  =  at'^2  +  bt'.    In  this  case,  after  activating  the  SOLVE  soft  menu,  and 

pressing  SSSSH  you  will  get  the  following  screen: 

Z": 

i     II  .  II  t  II  h  \m3m  i 

Within  this  SOLVR  environment  you  can  provide  values  for  any  of  the 
variables  listed  by  entering  the  value  in  the  stack  and  pressing  the 
corresponding  soft-menu  keys.  For  example,  say  you  enter  the  values  Q  =  14, 
a  =  2,  and  b  =  3.  You  would  use:  14  [   Q   ],  2  [   a   ],  3  [   b  ]. 
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As  variables  Q,  a,  and  b,  get  assigned  numerical  values,  the  assignments  are 
listed  in  the  upper  left  corner  of  the  display.  At  this  point  we  can  solve  for  t,  by 
usinaGnDf   t   1.  The  result  is  t:  2.    Pressing  SSIS  shov/s  the  results: 


4: 

3: 

t:2. 

Z: 

Left: 14 

l: 

Righit:  14. 

1  1 

1 

1  h  \m3iB\ 

Example  3  -  Solving  two  simultaneous  equations,  one  at  a  time 
You  can  also  solve  more  than  one  equation  by  solving  one  equation  at  a  time, 
and  repeating  the  process  until  a  solution  is  found.  For  example,  if  you  enter 
the  follov^ing  list  of  equations  into  variable  EQ:  {  'a*X+b*Y  =  c',  'k*X*Y=s'}, 
the  keystroke  sequence  EaSSi  EluiSIa,  within  the  SOLVE  soft  menu,  will  produce 
the  following  screen: 


l: 


r^nrni-r 


The  first  equation,  namely,  a*X  +  b*Y  =  c,  will  be  listed  in  the  top  part  of  the 
display.  You  can  enter  values  for  the  variables  a,  b,  and  c,  say: 
2[a   ]5[   b   ]  19[c   ].  Also,  since  we  can  only  solve  one  equation  at 
a  time,  let's  enter  a  guess  value  for  Y,  say,  0  [   Y   ],  and  solve  for  X,  by  using 
IjiJ  [   X   ].  This  gives  the  value,  X:  9.4999....  To  check  the  value  of  the 
equation  at  this  point,  press  OilSid.  The  results  are:     Left:  19,  Right:  19.  To 
solve  the  next  equation,  press  L/wrj  [jl^'u.  The  screen  shows  the  soft  menu  keys  as: 


X: 9. 50000000002 
Left: 19 
Right: 19 
^rni  X  II  V  II  


Say  we  enter  the  values  k  =  2,  s  =  12.  Then  solve  for  Y,  and  press 
!lS33a.  The  results  are  now,  Y: 


/: 

6: 

X: 9. 50000000002 

5: 

Left: 19. 

4: 

Right: 19 

3: 

Y: .631573547368 

2: 

Left: 12. 

l: 

Right: 12 

h 

■n|HH|BH|El{PR=|  nuzi 

We  then  continue  moving  from  the  first  to  the  second  equation,  back  and  forth, 
solving  the  first  equation  for  X  and  the  second  for  Y,  until  the  values  of  X  and 
Y  converge  to  a  solution.   To  move  from  equation  to  equation  use  iMII:!!.  To 
solve  for  X  and  Y  use  (3D  [  X  ],  andCfD[  Y  ],  respectively.   The  following 
sequence  of  solutions  is  produced: 
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/: 

X:7. 92105263162 

6: 

Y: .757475033056 

5: 

X: 7. 60631229237 

4: 

Y: .733313519325 

3: 

X: 7. 5279537017 

2: 

Y: .797029343928 

l: 

X: 7. 5074266402 

1    K    II    h    II    V    II    c  llitld^ 

Y: .799203603693 

=:  X: 7. 50197347325 

5:  Y: .799739017976 

4:  X: 7. 50052745505 

3:  Y: .799943742032 
2:  X: 7. 5001406448 

1 :  Y: .799934993 1 67 

II  X  II  V  II  .  Iiiiijairtiia 


After  solving  the  two  equations,  one  at  a  time,  we  notice  that,  up  to  the  third 
decimal,  X  is  converging  to  a  value  of  7.500,  while  Y  is  converging  to  a 
value  o  0.799. 


Using  units  with  the  SOLVR  sub-menu 

These  are  some  rules  on  the  use  of  units  with  the  SOLVR  sub-menu: 

•  Entering  a  guess  with  units  for  a  given  variable,  will  introduce  the  use 
of  those  units  in  the  solution. 

•  If  a  new  guess  is  given  without  units,  the  units  previously  saved  for 
that  particular  variable  are  used. 

•  To  remove  units  enter  a  number  without  units  in  a  list  as  the  new 
guess,  i.e.,  use  the  format  {  number }. 

•  A  list  of  numbers  can  be  given  as  a  guess  for  a  variable.  In  this  case, 
the  units  takes  the  units  used  belong  to  the  last  number  in  the  list.  For 
example,  entering  {  1 .41_ft  l_cm  l_m  }  indicates  that  meters  (m)  will 
be  used  for  that  variable. 

•  The  expression  used  in  the  solution  must  have  consistent  units,  or  an 
error  will  result  when  trying  to  solve  for  a  value. 


The  DIFFE  sub-menu 

The  DIFFE  sub-menu  provides  a  number  of  functions  for  the  numerical  solution 
of  differential  equations.  The  functions  provided  are  the  following: 


l: 


RRK   RKF^T  RRKfT  RKFER  R^EER 


These  functions  are  presented  in  detail  in  Chapter  1 6. 


The  POLY  sub-menu 

The  POLY  sub-menu  performs  operations  on  polynomials.  The  functions 
included  are  the  followinc 


PROOT  PCOEF  PEVflL 
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Function  PROOT 

This  function  is  used  to  find  tfie  roots  of  a  polynomial  given  a  vector 
containing  tfie  polynomial  coefficients  in  decreasing  order  of  tfie  powers  of 
tfie  independent  variable.  In  other  v/ords,  if  the  polynomial  is  a^x"  +  a„.ix"'^ 
+  ...  +  a2X^  +  OiX  +  Oo,  the  vector  of  coefficients  should  be  entered  as  [a„,  a„. 
1,  ...  ,  02,  Oi  ,  Oq].  For  example,  the  roots  of  the  polynomial  v/hose 
coefficients  are  [1,  -5,  6]  are  [2,  3]. 

Function  PCOEF 

This  function  produces  the  coefficients  [a^,  a^.^,  ...  ,  02,  a,  ,  Oq]  of  o 
polynomial  a^x"  +  an.ix"'^  +  ...  +  a2X^  +  OiX  +  Oq,  given  a  vector  of  its  roots 
[ri,  r2,       rn].    For  example,  a  vector  whose  roots  ore  given  by 
[-1,  2,  2,  1,  0],  will  produce  the  following  coefficients:  [1,  -4,  3,  4,  -4,  0]. 
The  polynomial  is  x^  -  4x''  +  3x''  +  4x^  -  4x. 

Function  PEVAL 

This  function  evaluates  a  polynomial,  given  a  vector  of  its  coefficients,  [a„,  a„. 

1,  ...  ,  02,  a,  ,  Oq],  and  a  value  Xg,  i.e.,  PEVAL  calculates  a^Xg"  +  a„.iXo""^  +  ... 
+  02X0^  +  a,Xo  +  Gq-  For  example,  for  coefficients  [2,  3,  -1,  2]  and  a  value  of 

2,  PEVAL  returns  the  value  28. 

The  SYS  sub-menu 

The  SYS  sub-menu  contains  a  listing  of  functions  used  to  solve  linear  systems. 
The  functions  listed  in  this  sub-menu  are: 


These  functions  are  presented  in  detail  in  Chapter  1 1 . 


The  TVM  sub-menu 

The  TVM  sub-menu  contains  functions  for  calculating  Time  Value  of  Money. 
This  is  an  alternative  way  to  solve  FINANCE  problems  (see  Chapter  6).  The 
functions  available  are  shown  next: 


£OLVR  TVHRO  HHORT  REG  i 
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The  SOLVR  sub-menu 

The  SOLVR  sub-menu  in  the  TVM  sub-menu  will  launch  the  solver  for  solving 
TVM  problems.  For  example,  pressing  iSSlSia,  at  this  point,  will  trigger  the 
following  screen: 


As  an  exercise,  try  using  the  values  n  =  1 0,  l%YR  =  5.6,  PV  =  1 0000,  and  FV 

=  0,  and  enter  I3D[  PMT  ]  to  find  PMT  = -1 021 .08....  Pressing  (W), 

produces  the  following  screen:  

112.  payment s^^year 

BEGIN  mode 

5: 

4: 

3: 

Z: 

l:   PMT:  [-1S21 .030364331 
ll^*"  

Press  I VAR  J  to  exit  the  SOLVR  environment.    Find  your  way  back  to  the  TVM 
sub-menu  within  the  SOLVE  sub-menu  to  try  the  other  functions  available. 

Function  TVMROOT 

This  function  requires  as  argument  the  name  of  one  of  the  variables  in  the 
TVM  problem.  The  function  returns  the  solution  for  that  variable,  given  that 
the  other  variables  exist  and  have  values  stored  previously.  For  example, 
having  solved  a  TVM  problem  above,  we  can  solve  for,  say,  'N',  as  follows: 
[  '  ]  lEEIiE].  The  result  is  1 0. 


Function  AMORT 

This  function  takes  a  value  representing  a  period  of  payment  (between  0  and 
n)  and  returns  the  principal,  interest,  and  balance  for  the  values  currently 
stored  in  the  TVM  variables.  For  example,  with  the  data  used  earlier,  if  we 
activate  function  AMORT  for  a  value  of  1 0,  we  get: 


4: 

3:  -3333.33933935 

2:  -210.S0S64S34S 

1 :  . 00000004766 


SOLVR  TVMRO  AMORT  REG  i 
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Function  BEG 

If  selected,  the  TMV  calculations  use  payments  at  the  beginning  of  each 
period.  If  deselected,  the  TMV  calculations  use  payments  at  the  end  of  each 
period. 
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Chapter  7 

Solving  multiple  equations 

Many  problems  of  science  and  engineering  require  the  simultaneous  solutions 
of  more  than  one  equation.  The  calculator  provides  several  procedures  for 
solving  multiple  equations  as  presented  belov/.  Please  notice  that  no 
discussion  of  solving  systems  of  linear  equations  is  presented  in  this  chapter. 
Linear  systems  solutions  will  be  discussed  in  detail  in  subsequent  chapters  on 
matrices  and  linear  algebra. 

Rational  equation  systems 

Equations  that  can  be  re-written  as  polynomials  or  rational  algebraic 
expressions  can  be  solved  directly  by  the  calculator  by  using  the  function 
SOLVE.  You  need  to  provide  the  list  of  equations  as  elements  of  a  vector. 
The  list  of  variables  to  solve  for  must  also  be  provided  as  a  vector.  Make  sure 
that  the  CAS  is  set  to  mode  Exact  before  attempting  a  solution  using  this 
procedure.    Also,  the  more  complicated  the  expressions,  the  longer  the  CAS 
takes  in  solving  a  particular  system  of  equations.    Examples  of  this 
application  follow: 

Example  1  -  Projectile  motion 

Use  function  SOLVE  with  the  following  vector  arguments,  the  first  being  the  list 
of  equations:  ['x  =  xO  +  vO*COS(eO)*t'  'y  =yO+vO*SIN(eO)*t  - 
g*fA2/2'][w7Hj,  and  the  second  being  the  variables  to  solve  for,  say  t  and  yO, 
i.e.,  [Y  'yO']. 

The  solution  in  this  case  will  be  provided  using  the  RPN  mode.  The  only 
reason  being  that  we  can  build  the  solution  step  by  step.   The  solution  in  the 
ALG  mode  is  very  similar.    First,  we  store  the  first  vector  (equations)  into 
variable  A2,  and  the  vector  of  variables  into  variable  Al .  The  following 
screen  shows  the  RPN  stack  before  saving  the  variables. 


6: 

5; 

3:  'fl2' 
l:  'fll 
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At  this  point,  we  need  only  press  [£n>j  twice  to  store  these  variables. 
To  solve,  first  change  CAS  mode  to  Exact,  then,  list  the  contents  of  A2  and  Al, 
in  that  order: 


 Ct  \)01 


Use  command  SOLVE  at  this  point  (from  the  S.SLV  menu:  CHDj^  )  After 
about  40  seconds,  maybe  more,  you  get  as  result  a  list: 

{ 't  =  (x-xO)/(COS(0O)*vO)' 

'yO  =  (2*COS(eO)''2*vO'^2*y+(g*x^2(2*xO*g+2*SIN(eO))*COS(eO)*vO'^2)*x+ 
(xO'^2*g+2*SIN(eO)*COS(eO)*vO'^2*xO)))/(2*COS(eO)'^2*vO'^2)']} 


Press  {.lyAL)  to  remove  the  vector  from  the  list,  then  use  command  OBJ^,  to  get 
the  equations  listed  separately  in  the  stack. 


5: 
4: 
3: 
Z: 


4: 
3: 

2: 
l: 


•J0-- 


Note:  This  method  worked  fine  in  this  example  because  the  unknowns  t  and 
yO  were  algebraic  terms  in  the  equations.  This  method  would  not  work  for 
solving  for  00,  since  90  belongs  to  a  transcendental  term. 


Example  2  -  Stresses  in  a  thick  wall  cylinder 

Consider  a  thick-wall  cylinder  for  inner  and  outer  radius  a  and  b,  respectively, 
subject  to  an  inner  pressure  P,  and  outer  pressure  P^.  At  any  radial  distance  r 
from  the  cylinder's  axis  the  normal  stresses  in  the  radial  and  transverse 
directions,  cj„  and  099,  respectively,  are  given  by 

0  -a  r  -(p  -a  ) 

-b'-P^  a'-b'-iP-P^) 


a'-P 


■a 


r^-(b^-a^) 
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Notice  that  the  right-hand  sides  of  the  two  equations  differ  only  in  the  sign 
between  the  two  terms.  Therefore,  to  write  these  equations  in  the  calculator,  I 
suggest  you  type  the  first  term  and  store  in  a  variable  Tl ,  then  the  second  term, 
and  store  it  in  12.  Writing  the  equations  afterwards  will  be  matter  of  recalling 
the  contents  of  Tl  and  T2  to  the  stack  and  adding  and  subtracting  them. 
Here  is  how  to  do  it  with  the  equation  writer: 
Enter  and  store  term  11 : 


2  2 
a  'Pi-b  'Pq 

b  -a 


EDIT   CURS   EIG  ■  EVflL  FflCTO  SIMP 


4: 

3: 

2: 

2  2 

a  .Pi-b  .Po 

b  -a 

l: 

'Tl ' 

Enter  and  store  term  T2: 


a^'b^<Pi-PQ) 
r^.(b^-a^  ) 


EDIT   CURS   RIG  ■  EVflL  FflCTD  SIMP 


4: 

3: 

2: 

2  2 

a  'b  ■tPi-Po) 

r^.(b^-a^) 

l: 

'T2' 

Notice  that  we  are  using  the  RPN  mode  in  this  example,  however,  the 
procedure  in  the  ALG  mode  should  be  very  similar.  Create  the  equation  for 
age.  CnDBKiaBSEESaiC+D  (d^lCSO  (^CEDS       CD  CED^ 
Create  the  equation  for  tjrr:  CjDSSHBIEIBS  CHD  (^™)CEDO  (^™)I3D0 
CD 


Put  together  a  vector  with  the  two  equations,  using  function  ^ARRY  (find  it 


using  the  command  catalog  LrLJ— ^  )  a 


3: 
l: 


Sr. —  Sr..  .a 


lb  -a 

.j-.pi-b".F»  j".b^.tPi-P») 


r2.(b2-.2) 


ter  typing  a  L  2  J : 


5: 
4: 
3: 


1=  r 


Now,  suppose  that  we  want  to  solve  for  P,  and  P^,  given  a,  b,  r,  cr,,,  and  aee- 
We  enter  a  vector  with  the  unknowns: 


2: 
l: 


a^.pi-b^.p*  .  a^.b^.(Pi-P*) 


cpi  p*: 
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To  solve  for  P,  and  P^,  use  the  command  SOLVE  from  the  S.SLV  menu 
([  <-i  }s.5Lv  )^  it  may  take  the  calculator  a  minute  to  produce  the  result: 
{['Pi=-(((cTe-ar)*r'^2-(ae+ar)*a'^2)/(2*a'^2))' 
'Po=-(((a9-ar) * r^ 2-(g9+ar ) * 2)/(2 * 2))'  ]  },  i.e., 


Notice  that  the  result  includes  a  vector  [  ]  contained  within  a  list  { }.  To  remove 
the  list  symbol,  use  dwT).  Finally,  to  decompose  the  vector,  use  function  OBJ^. 
The  result  is: 


Pi 


12. i 


These  tv/o  examples  constitute  systems  of  linear  equations  that  can  be  handled 
equally  v/ell  v/ith  function  LINSOLVE  (see  Chapter  1  1 ).  The  following 
example  shows  function  SOLVE  applied  to  a  system  of  polynomial  equations. 


Example  3  -  System  of  polynomial  equations 

The  following  screen  shot  shows  the  solution  of  the  system  X^+XY=1 0,  X^-Y^=-5, 
using  function  SOLVE: 


[x  +X.V=10  X  -Y  =-5] 
r  2  2  2' 

LX  +Y.X=10  X  -Y  =-5. 

SOLVEtflHSd) '[X  Y]') 
{[X=2  Y=3]  [X=-2  Y=-3]} 


Solution  to  simultaneous  equations  with  MSLV 


Function  MSLV  is  availab 


as  the  last  option  in  the  [  r>  jiMtsLv  menu: 


1 

a 

diff  sn.. 

3 

poly.. 

H 

lin  fyj.. 

5 

Solus 

finjnci.. 

MSLV 

The  help-facility  entry  for  function  MSLV  is  shown  next: 
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Non-po 1 ynom ial  multi- 
variate so Iyer 
MSLVt ' [SIHtX>+Y,X+SIHt 
V>=1] ' , ' [X, Y] ' , [0,0]> 
[1.S23S41 12611  -.9631... 
See:  SOLVE 


EXIT   ECHO   f  EEl   £EE2   iZZ3  HHIH 


Example  1  -  Example  from  the  help  facility 

As  with  all  function  entries  in  the  help  facility,  there  is  an  example  attached  to 
the  MSLV  entry  as  shown  above.  Notice  that  function  MSLV  requires  three 
arguments: 

1 .  A  vector  containing  the  equations,  i.e.,  '[SIN(X)+Y,X+SIN(Y)=1  ]' 

2.  A  vector  containing  the  variables  to  solve  for,  i.e.,  '[X,Y]' 

3.  A  vector  containing  initial  values  for  the  solution,  i.e.,  the  initial  values 
of  both  X  and  Y  are  zero  for  this  example. 

In  ALG  mode,  press  IHIjIIj  to  copy  the  example  to  the  stack,  press  to  run 
the  example.  To  see  all  the  elements  in  the  solution  you  need  to  activate  the 
line  editor  by  pressing  the  down  arrow  key  ("^^ ): 


HELP 

MSLV(TSIH(X)+Y  X+SIHm:^ 
{[SIH(X)+Y  X+SIH(Y)=1.] 
4[SIHtX>+Y,X+SIHtY>=l 
[X,Y], 

[1.S23S41 12611, -.9631 


t^KIP  SKIP-H  H)EL   DEL-f  DEL  L  inS  i 


in  RPN  mode,  the  solution  for  this  example  is  produced  by  using: 

W-  ] 

3:  [SIH(X)+Y  X+SIH(Y)=1.] 
2:  [X  Y] 

l:  [0.  0.] 


CflSCM  HELP 


Activating  function  MSLV  results  in  the  following  screen. 


4: 

3:  [SIH(X)+Y  X+SIH(Y)=1.] 
2:  [X  Y] 

l:  [1.32334112611  -.S6i> 


CflSCH  HELP 


You  may  hove  noticed  that,  while  producing  the  solution,  the  screen  shows 
intermediate  information  on  the  upper  left  corner.  Since  the  solution  provided 
by  MSLV  is  numerical,  the  information  in  the  upper  left  corner  shows  the 
results  of  the  iterative  process  used  to  obtain  a  solution.   The  final  solution  is  X 
=  1.8238,  Y  = -0.9681. 
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Example  2  -  Entrance  from  a  lake  into  an  open  channel 

This  particular  problem  in  open  channel  flow  requires  the  simultaneous 

solution  of  two  equations,  the  equation  of  energy:  H ^  =  y   /  and 

2g 

Manning's  equation:  Q  =  JTi'y^o  •      these  equations,  Hq 

n  P 

represents  the  energy  head  (m,  or  ft)  available  for  a  flow  at  the  entrance  to  a 
channel,  y  is  the  flow  depth  (m  or  ft),  V  =  Q/A  is  the  flow  velocity  (m/s  or 
ft/s),  Q  is  the  volumetric  discharge  (mVs  or  ft'^/s),  A  is  the  cross-sectional 
area  (m^  or  ft^),      is  a  coefficient  that  depends  on  the  system  of  units  (C^,  = 
1 .0  for  the  SI,  Q  =  1 .486  for  the  English  system  of  units),  n  is  the  Manning's 
coefficient,  a  measure  of  the  channel  surface  roughness  (e.g.,  for  concrete,  n 
=  0.01  2),  P  is  the  wetted  perimeter  of  the  cross  section  (m  or  ft),     is  the 
slope  of  the  channel  bed  expressed  as  a  decimal  fraction.    For  a  trapezoidal 
channel,  as  shown  below,  the  area  is  given  by  A  =  {b-\-  my)y  ,  while  the 

wetted  perimeter  is  given      P  =  b  +  2y^^\  +  m  ,  where  b  is  the  bottom 
width  (m  or  ft),  and  m  is  the  side  slope  (1  V:mH)  of  the  cross  section. 

Typically,  one  has  to  solve  the  equations  of  energy  and  Manning's 
simultaneously  for  y  and  Q.  Once  these  equations  are  written  in  terms  of  the 
primitive  variables  b,  m,  y,  g,  S^,  n,  Cu,  Q,  and  H^,  we  are  left  with  a  system 
of  equations  of  the  form  fi{y,Q)  =  0,  f2(y/Q)  =  0.   We  can  build  these  two 
equations  as  follows. 

We  assume  that  we  will  be  using  the  ALG  and  Exact  modes  in  the  calculator, 
although  defining  the  equations  and  solving  them  with  MSLV  is  very  similar  in 
the  RPN  mode.   Create  a  sub-directory,  say  CHANL  (for  open  CHANneL), 
and  within  that  sub-directory  define  the  following  variables: 


:Ho=y-^|;^^EQl 

5 

3 

:  Q=— ■^■■JSo  ►EQ2 
n  d 
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n.3Jp 

Q 

R 

£ 
R 

2 


(b+m■y)■y^R 


b+^■y■Jl+[^l^^p 


2 

yb+y  •\'\ 


h+2 


r2~ 

ly.-Jm  +1 


To  see  the  original  equations,  EQl  and  EQ2,  in  terms  of  the  primitive 
variables  listed  above,  v/e  con  use  function  EVAL  applied  to  each  of  the 
equations,  i.e.,  (f^illlBi'lLllill  Ijyal]  .....  s  r  all.  The  equations  are  listed  in  the  stack 
as  follov/s  (small  font  option  selected): 


b+a-y.-Jl+H 


b+a.y.JH^+l 


EVHKEtl) 

l|.-6^*3'a^'3'b^*H.!)''.H.3.b*Z.!)^.H^.3 


Z.ij^.3.b^tH.a^.H.3.b*Z.a''.H^.3 


a    a     3  Ha 

EVAL(ECa) 

3  I  ' 


'I — ri=' 

n.  -Jb+a.y.-jH  +1 


We  can  see  that  these  equations  are  indeed  given  in  terms  of  the  primitive 
variables  b,  m,  y,  g,  S^,  n,  Cu,  Q,  and  H^. 


In  order  to  solve  for  y  and  Q  we  need  to  give  values  to  the  other  variables. 
Suppose  v/e  use  Hq  =  5  ft,  b  =  1 .5  ft,  m  =  1 ,  n  =  0.012,  Sq  =  0.00001,  g  = 
32.2,  and  Cu  =  1 .486.  Before  being  able  to  use  MSLV  for  the  solution,  we 
need  to  enter  these  values  into  the  corresponding  variable  names.  This  can 
be  accomplished  as  follov/s:  


1 

:5^Ho 

5 

:  .01£frn 

.012 

: 1 . 5^b 

1.5 

. 00001 

:  It-n 

1 

32.2 
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: .00001 ►So 

.00001 

■■52. 2^9 

32.2 

: 1 . 4S6frCu 

1.4S6 

♦  

Now,  we  are  ready  to  solve  the  equation.  First,  we  need  to  put  the  two 
equations  together  into  a  vector.  We  can  do  this  by  actually  storing  the 
vector  into  a  variable  that  we  will  call  EQS  (EQuationS): 

■  1 . 4BbFLU  I 
1.4S6 

i[EQl  EQ2>EQS 


As  initial  values  for  the  variables  y  and  Q  we  will  use  y  =  5  (equal  to  the 
value  of  H„  which  is  the  maximum  value  that  y  can  take)  and  Q  =  1 0  (this  is 
a  guess).  To  obtain  the  solution  we  select  function  MSLV  from  the  NUM.SLV 
menu,  e.g.,  [  r>  jmisiy  [  6  ji83S8i,  to  place  the  command  in  the  screen: 

■  1 .  4Bb| 

i[EQl  EQ2>EQS 

H,=y!^  ,,R.Js3.Cu.3.j 
r..3Jp' 


Next,  we'll  enter  variable  EQS:  (W][W]||| 


,  followed  by  vector  [y,Q]: 


and  by  the  initial  guesses  Cj3  CSCil]  J  CDCOj- 

Before  pressing  [inter]  ^  the  screen  will  look  like  this: 

i[EQl  EQ2>EQS 

_V^+2.y.g  R.JSQ'CU'3J 

rrSJP 

MSLVtiEGS,  [Lj,G],  [5,  10]> 


Ho= 


Press  t»™j  to  solve  the  system  of  equations.  You  may,  if  your  angular 
measure  is  not  set  to  radians,  get  the  following  request: 
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:[EQ1  EQ2>EQS 

Ho 

no 

ISLVtiEGS,  [Lj,G],  [5,  1S4> 

1       1       1  icflncLl 

OK 

Press  E33i  and  allow  the  solution  to  proceed.  An  intermediate  solution  step 
may  look  like  this: 

|[4.99656S1627?,  IS.  901 11 

35SS229S62S6 

H,=y!^  ,,R.Js3.Cu.3j 
r..3Jp' 

The  vector  at  the  top  representing  the  current  value  of  [y,Q]  as  the  solution 
progresses,  and  the  value  .358822986286  representing  the  criteria  for 
convergence  of  the  numerical  method  used  in  the  solution.  If  the  system  is 
v/ell  posed,  this  value  v/ill  diminish  until  reaching  a  value  close  to  zero.  At  that 
point  a  numerical  solution  v/ould  have  been  found.  The  screen,  after  MSLV 
finds  a  solution  will  look  like  this: 


rrS-JP 

MSLV(EQS,[y  Q],[5  10]) 


The  result  is  a  list  of  three  vectors.  The  first  vector  in  the  list  will  be  the 
equations  solved.  The  second  vector  is  the  list  of  unknowns.  The  third  vector 
represents  the  solution.  To  be  able  to  see  these  vectors,  press  the  down-arrow 
key       to  activate  the  line  editor.  The  solution  will  be  shown  as  follows: 


^HD  aiz  HEX 

CHOHE  EX2> 


HLG 


2.9 


n.3Jp'1 
4  [  Ho=  c:  V-^2+2*y*9  >  ^  <  2*9. 

[4. 99369613276, 20. 661. 


t^KIP  SKIP-H  H)EL   DEL-f  DEL  L  IRS  i 


The  solution  suggested  is  [4.9936..,  20.661 ...].  This  means,  y  =  4.99  ft,  and 
Q  =  20.661 ...  ftVs.  You  can  use  the  arrow  keys  (cX)CD<^'^)  to  see  the 
solution  in  detail. 
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Using  the  Multiple  Equation  Solver  (MES) 

The  multiple  equation  solver  is  an  environment  where  you  can  solve  a  system 
of  multiple  equations  by  solving  for  one  unknown  from  one  equation  at  a  time. 
It  is  not  really  a  solver  to  simultaneous  solutions,  rather,  it  is  a  one-by-one 
solver  of  a  number  of  related  equations.  To  illustrate  the  use  of  the  MES  for 
solving  multiple  equations  we  present  an  application  related  to  trigonometry  in 
the  next  section.  The  examples  shown  here  are  developed  in  the  RPN  mode. 

Application  1  -  Solution  of  triangles 

In  this  section  we  use  one  important  application  of  trigonometric  functions: 
calculating  the  dimensions  of  a  triangle.  The  solution  is  implemented  in  the 
calculator  using  the  Multiple  Equation  Solver,  or  MES. 
Consider  the  triangle  ABC  shown  in  the  figure  below. 


B  c  A 

The  sum  of  the  interior  angles  of  any  triangle  is  always  1  80°,  i.e.,  a  +  (3  +  y  = 
1  80°.  The  sine  law  indicates  that: 


sin«     sin/?  siny 


a         o  c 

The  cosine  law  indicates  that: 

=  ti^  +  -  2-b-c -cos  a, 
=  a^  +  -  2-a-c -cos  /?, 
=     +     -  2-a-bcos  y. 

In  order  to  solve  any  triangle,  you  need  to  know  at  least  three  of  the  following 
six  variables:  a,  b,  c,  a,  ji,  y.   Then,  you  can  use  the  equations  of  the  sine  law. 
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cosine  law,  and  sum  of  interior  angles  of  a  triangle,  to  solve  for  the  other 
three  variables. 

If  the  three  sides  are  knov/n,  the  area  of  the  triangle  can  be  calculated  with 

Heron's  formula  A  =  -yjs  •  {s  —  a)- {s  —  b)  •  (s  —  c)  , where  s  is  known  as  the 

,  ,          ,              a  +  b  +  c 
semi-perimeter  of  the  triangle,  i.e.,  s  =  ^  . 

Triangle  solution  using  the  Multiple  Equation  Solver  (MES) 

The  Multiple  Equation  Solver  (MES)  is  a  feature  that  can  be  used  to  solve  two 
or  more  coupled  equations.  It  must  be  pointed  out,  however,  that  the  MES 
does  not  solve  the  equations  simultaneously.  Rather,  it  takes  the  known 
variables,  and  then  searches  in  a  list  of  equations  until  it  finds  one  that  can  be 
solved  for  one  of  the  unknown  variables.  Then,  it  searches  for  another 
equation  that  can  be  solved  for  the  next  unknowns,  and  so  on,  until  all 
unknowns  have  been  solved  for. 


Creating  a  working  directory 

We  will  use  the  MES  to  solve  for  triangles  by  creating  a  list  of  equations 
corresponding  to  the  sine  and  cosine  laws,  the  law  of  the  sum  of  interior 
angles,  and  Heron's  formula  for  the  area.  First,  create  a  sub-directory  within 
HOME  that  we  will  coll  TRIANG,  and  move  into  that  directory.  See  Chapter 
2  for  instructions  on  how  to  create  a  new  sub-directory. 

Entering  the  list  of  equations 

Within  TRIANG,  enter  the  following  list  of  equations  either  by  typing  them 

directly  on  the  stack  or  by  using  the  equation  writer.   (Recall  that  [alpha]^  ](a\ 

produces  the  character  a,  and  [AimA]l  r»  ](S\  produces  the  character  p.  The 
character  y  needs  to  be  EEEEled  from  [  r»  J  Q^'g ): 

'SIN(a)/a  =  SIN(p)/b' 

'SIN(a)/a  =  SIN(y)/c' 

'SIN(p)/b  =  SIN(y)/c' 
'c'^2  =  a'^2-i-b''2-2*a*b*COS(Y)' 
'b''2  =  a''2-i-c''2-2*a*c*COS(p)' 
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=  b'^2+c'^2-2*b*c*COS(a)' 
'a+p+Y  =  1  80' 
's  =  (a+b+c)/2' 
'A  =  V  (s*(s-a)*(s-b)*(s-c))' 

Then,  enter  the  number  m,  and  create  a  list  of  equations  by  using:  function 
^LIST  (use  the  command  catalog  L    J  cat  ).  Store  this  list  in  the  variable  EQ. 

The  variable  EQ  contains  the  list  of  equations  that  v/ill  be  scanned  by  the  MES 
v/hen  trying  to  solve  for  the  unknov/ns. 

Entering  a  window  title 

Next,  we  will  create  a  string  variable  to  be  called  TITLE  to  contain  the  string 
"Triangle  Solution",  as  follows: 

CED  " 

[alpha]  {AimA\  [  »-i  J  [alpha] 

^(i](^(]}®(E\(s\Qm^ 
^(i\(o\a\is\m(i\@m 

[entcr] 

(AmA}  (alpha}  (t](J]  O  (3  (S  [intck] 

Creating  a  list  of  variables 

Next,  create  a  list  of  variable  names  in  the  stack  that  will  look  like  this: 

{  abcaPyAs  } 
and  store  it  in  variable  LVARI  (List  of  VARIables).  The  list  of  variables 
represents  the  order  in  which  the  variables  will  be  listed  when  the  MES  gets 
started.  It  must  include  all  the  variables  in  the  equations,  or  it  will  not  work 
with  function  MITM  (see  below).    Here  is  the  sequence  of  keystrokes  to  use  to 
prepare  and  store  this  list: 

Press  L  w«  J ,  if  needed,  to  get  your  variables  menu.  Your  menu  should  show 
the  variables  EEEIIi!  lEEIilEi  IES3S  . 


Open  double  quotes  in  stack 
Locks  keyboard  into  lower-case  alpha. 
Enter  text:  Triangle_ 
Enter  text:  Solution 

Enter  string  "Triangle  Solution"  in  stack 
Open  single  quotes  in  stack 
Enter  variable  name  'TITLE' 
Store  string  into  'TITLE' 
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Preparing  to  run  the  MES 

The  next  step  is  to  activate  the  MES  and  try  one  sample  solution.  Before  we 
do  that,  however,  we  want  to  set  the  angular  units  to  DEGrees,  if  they  are  not 
already  set  to  that,  by  typing  (^^(^i™)(5](T](g](^). 

Next,  we  want  to  keep  in  the  stack  the  contents  of  TITLE  and  LVARI,  by  using: 

■r<ni  i^jilifi 

We  will  use  the  following  MES  functions 

•  MINIT:  MES  INITialization:  initializes  the  variables  in  the  equations 
stored  in  EQ. 

•  MITM:  MES'  Menu  Item:  Takes  a  title  from  stock  level  2  and  the  list  of 
variables  from  stack  level  1  and  places  the  title  atop  of  the  MES 
window,  and  the  list  of  variables  as  soft  menu  keys  in  the  order 
indicated  by  the  list.  In  the  present  exercise,  we  already  have  a  title 
("Triangle  Solution")  and  a  list  of  variables  ({abcaPyAs}) 
in  stack  levels  2  and  1 ,  respectively,  ready  to  activate  MITM. 

•  MSOLVR:  MES  SOLVER;  activates  the  Multiple  Equation  Solver  (MES) 
and  waits  for  input  by  the  user. 

Running  the  MES  interactively 

To  get  the  MES  started,  with  the  variables  TITLE  and  LVARI  listed  in  the  stack, 
activate  command  MINIT,  then  MITM,  and  finally,  MSOLVR  (find  these 
functions  in  the  catalog  (.    J  cat  ). 

The  MES  is  launched  with  the  following  list  of  variables  available  (Press  [wj 
to  see  the  next  list  of  variables): 


-iL  ■ 
1  : 

n    II    t.    II          II    «    II    e  II 

H    II    ^  II 

II 

II 

iKm 

Press  [A/xrj  to  see  the  third  list  of  variables.  You  should  see: 

^na™  I  1 

Press  (wT)  once  more  to  recover  the  first  variable  menu. 

Let's  try  a  simple  solution  of  Case  I,  using  a  =  5,  b  =  3,  c  =  5.  Use  the 
following  entries: 
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L5J  [  a  ]  a:5  is  listed  in  the  top  left  corner  of  the  display. 
(.  3  J  [  b  ]  b:3  is  listed  in  the  top  left  corner  of  the  display. 
L5J  [  c  ]  c:5  is  listed  in  the  top  left  corner  of  the  display. 
To  solve  for  the  angles  use: 

I  <n  J[  a  ]         Calculator  reports  Solving  for  a,  and  shov/s  the  result  a: 
72.5423968763. 

Note:  If  you  get  a  value  that  is  larger  than  1 80,  try  the  follov/ing: 


UJ^[  a  ] 
CS3 [   a  ] 


Re-initialize  a  to  a  smaller  value. 
Calculator  reports  Solving  for  a 


Next,  we  calculate  the  other  two  values: 
CfD  [    P   ]  The  result  is  P :  34.9152062474 

C5D  [   Y    ]  The  result  is  y:  72.5423968763. 

You  should  have  the  values  of  the  three  angles  listed  in  stack  levels  3  through 
1 .  Press  I  +  J  twice  to  check  that  they  add  indeed  to  1 80°. 


4: 

432.542396S76 

3: 

o:: 

72.5423963762 

2: 

p- 

34.9152062475 

l: 

72.5423963762 

mmm 

mm 

m  «  II  ^  II  .  . 

|i  o::432 

^iBjjMjr 


,542396376 
130 


Press  [nxt]  to  move  to  the  next  variables  menu.  To  calculate  the  area  use: 
I  *n  J[  A  ].  The  calculator  first  solves  for  all  the  other  variables,  and  then 
finds  the  area  as  A:  7.15454401063. 


4: 

3: 

o:: 

432.542396376 

2: 

130. 

l: 

R: 

7. 15454401063 

h  HI 

f  HI 



Note:  When  a  solution  is  found,  the  calculator  reports  the  conditions  for  the 
solution  as  either  Zero,  or  Sign  Reversal.    Other  messages  may  occur  if  the 
calculator  has  difficulties  finding  a  solution. 

Pressing  Ljnjlljlll  will  solve  for  all  the  variables,  temporarily  showing  the 
intermediate  results.    Press  (.  r»  JBHSI  to  see  the  solutions: 
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■v:  72.542396S763 


p:  34.9152062474 

o::  72.5423963762 

s:  6.5 

R:  7.15454401063 


When  done,  press  I  on  J  to  return  to  the  MES  environment.  Press  I  w«  j  to  exit 
the  MES  environment  and  return  to  the  normal  calculator  display. 

Organizing  the  variables  in  the  sub  directory 

Your  variable  menu  will  now  contain  the  variables  (press  I^xt]  to  see  the 
second  set  of  variables): 


Hporl   E4  ITITLEILVflRI 


Variables  corresponding  to  all  the  variables  in  the  equations  in  EQ  have  been 
created.  There  is  also  a  new  variable  called  Mpar  (MES  parameters),  which 
contains  information  regarding  the  setting  up  of  the  MES  for  this  particular  set 
of  equations.  If  you  use  L  r»  JsjiHSSil  to  see  the  contents  of  the  variable  Mpar. 
You  will  get  the  cryptic  message:  Library  Data.  The  meaning  of  this  is  that  the 
MES  parameters  are  coded  in  a  binary  file,  which  cannot  be  accessed  by  the 
editor. 

Next,  we  want  to  place  them  in  the  menu  labels  in  a  different  order  than  the 
one  listed  above,  by  following  these  steps: 

1.  Create  a  list  containing  {  EQ  Mpar  LVARI  TITLE  },  by  using: 

I  *n  JU        ■ulsh  i.!  :.  \jmss  mssmss  [enter] 

2.  Place  contents  of  LVARI  in  the  stack,  by  using:  ll]EEI3i3. 

3.  Join  the  two  lists  by  pressing  I  +  J . 

Use  function  ORDER  (use  the  command  catalog  (.  r»  J  o>r  )  to  order  the 
variables  as  shown  in  the  list  in  stack  level  1 . 

4.  Press  (.    J  to  recover  your  variables  list.  It  should  now  look  like  this: 


EC   I  Hpor  |LVHRI|TITLE|  1 


5.    Press  [nxt)  to  recover  the  first  variable  menu. 
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Programming  the  MES  triangle  solution  using  User  RPL 

To  facilitate  activating  the  MES  for  future  solutions,  we  will  create  a  program 
tfiat  will  load  tfie  MES  witfi  a  single  keystroke.  Tfie  program  sfiould  look  like 
tfiis:  «  DEG  MINIT  TITLE  LVARI  MITM  MSOLVR  »,  and  can  be  typed  in 
by  using: 

[    J  «  »  Opens  the  program  symbol 

[alpha) [ALPHA]  Locks  alphanumeric  keyboard 

(d](e](g]{jk)  Type  in  DEG  (angular  units  set  to  DEGrees) 

(3 (SI  (3 (3 Type  in  MINIT_ 
[awha]  Unlocks  alphanumeric  keyboard 

SSIjIj^j  List  the  name  TITLE  in  the  program 

S3333[3  List  the  name  LVARI  in  the  program 

(AiM^\AiPH^  Locks  alphanumeric  keyboard 

(m\(J](t](m\ [spc J  Type  in  MITM_ 

(3  O  (§1  (3  (3  (3  Type  in  MSOLVR 

(Bf§]  Enter  program  in  stock 

Store  the  program  in  a  variable  called  TRISOL,  for  TRIangle  SOLution,  by 
using:  CZIl(^™)(d™)(3(51(3(21(§l(3(^  (i^ 

Press  ChD/  if  needed,  to  recover  your  list  of  variables.   A  soft  key  label 
iijSijSS  should  be  available  in  your  menu. 

Running  the  program  -  solution  examples 

To  run  the  program,  press  the  yi.s.i3!.!i::yi!j  soft  menu  key.  You  will  now  have  the 
MES  menu  corresponding  to  the  triangle  solution.  Let's  try  examples  of  the 
three  cases  listed  earlier  for  triangle  solution. 

Example  1  -  Right  triangle 

Use  a  =  3,  b  =  4,  c  =  5.  Here  is  the  solution  sequence: 

CTJ  [  a  ]  C3I3  [  b  ]  CX)  [  c  ]  To  enter  data 

CfD[   a   ]  The  result  is  a:  36.8698976458 

C5D[   P   ]  The  result  is  p :  53.1301023541. 

CJtJ  [   y    ]  The  result  is  y:  90. 

[nxtJ  To  move  to  the  next  variables  menu. 

[«n][   A   ]  The  result  is  A;  6. 

[NXT]  [NXT]  To  move  to  the  next  variables  menu. 
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Example  2  -  Any  type  of  triangle 

Use  a  =  3,  b  =  4,  c  =  6.  The  solution  procedure  used  here  consists  of  solving 

for  all  variables  at  once,  and  then  recalling  the  solutions  to  the  stack: 

Lj«j  :.  i::.  To  clear  up  data  and  re-start  MES 

UJ  [  a  ]  C2J  [  b  ]  dD  [  c  ]  To  enter  data 

[hxt]  To  move  to  the  next  variables  menu. 

I  *i  J  Elaa  Solve  for  all  the  unknowns. 

I  r»  J  EEn  Shov/  the  solution 


The  solution  is: 


117.279612736 


36.3360575147 
o::  26.3343297495 
s:  6.5 

R:  5.33263225193 


At  the  bottom  of  the  screen,  you  v/ill  have  the  soft  menu  keys: 

EmsG-  ESSES  ussn  USSS  IBSSBS  gS13 


The  square  dot  in  EEISII"  indicates  that  the  values  of  the  variables,  rather  than 
the  equations  from  which  they  were  solved,  are  shown  in  the  display.  To  see 
the  equations  used  in  the  solution  of  each  variable,  press  the  11=1211^!  soft  menu 
key.    The  display  will  now  look  like  this: 


,  b-^2=a-^2+c-^2-2*a*.. 
'  a-^2=b-^2+c-^2-2*b*.. 
's=<a+b+c).^2' 
'R=Tts*ts-a>*<s-b.. 


VHLUE  Ecn^i  pRinr 


The  soft  menu  key  iijIIMLllj!  is  used  to  print  the  screen  in  a  printer,  if  available. 
And  liiSiLiiii  returns  you  to  the  MES  environment  for  a  new  solution,  if  needed. 
To  return  to  normal  calculator  display,  press  I  w«  J . 


The  following  table  of  triangle  solutions  shows  the  data  input  in  bold  face  and 
the  solution  in  italics.  Try  running  the  program  with  these  inputs  to  verify  the 
solutions.  Please  remember  to  press  (j«J  IIlIIjIIDEEI  at  the  end  of  each  solution  to 
clear  up  variables  and  start  the  MES  solution  again.  Otherwise,  you  may 
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carry  over  information  from  tfie  previous  solution  that  may  wreck  havoc  with 
your  current  calculations. 


a 

b 

c 

an 

PC) 

rC) 

A 

2.5 

6.9837 

7.2 

20.299 

75 

84.771 

8.6933 

7.2 

8.5 

14.26 

22.616 

27 

130.38 

23.309 

21.92 

17.5 

13.2 

90 

52.97 

37.03 

115.5 

41.92 

23 

29.6 

75 

32 

73 

328.81 

10.27 

3.26 

10.5 

77 

18 

85 

16.66 

17 

25 

32 

31.79 

50.78 

97.44 

210.71 

Adding  an  INFO  button  to  your  directory 

An  information  button  can  be  useful  for  your  directory  to  help  you  remember 
the  operation  of  the  functions  in  the  directory.  In  this  directory,  all  we  need  to 
remember  is  to  press  lilijillE!  to  get  a  triangle  solution  started.  You  may  want 
to  type  in  the  following  program:  «"Press  [TRISO]  to  start."  MSGBOX  »,  and 
store  it  in  a  variable  called  INFO.  As  a  result,  the  first  variable  in  your 
directory  will  be  the  131133  button. 

Application  2  -  Velocity  and  acceleration  in  polar  coordinates 

Two-dimensional  particle  motion  in  polar  coordinates  often  involves 
determining  the  radial  and  transverse  components  of  the  velocity  and 
acceleration  of  the  particle  given  r,  r'  =  dr/dt,  r"  =  d^r/dt^,  9,  6'  =  d  9  /dt, 
and,  0"  =  d^9/dt^.  The  following  equations  are  used: 

=r  =  'r  -  ru 

Vff  =r6     Gg  =r6  +  2rO 
Create  a  subdirectory  called  POLC  (POLar  Coordinates),  which  we  will  use  to 
calculate  velocities  and  accelerations  in  polar  coordinates.     Within  that 
subdirectory,  enter  the  following  variables: 
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Program  or  value  Store  into  variable: 

«  PEQ  STEQ  MINIT  NAME  LIST  MITM  MSOLVR  »  SOLVEP 

"vel.  &  acc.  polar  coord."  NAME 

{  r  rD  rDD  90  BDD  vr  vB  v  ar  aO  a  }  LIST 

{  'vr  =  rD'  've  =  r*eD'    'v  =  V(vr'^2  +  ve''2)' 
'or  =  rDD  -  r*eD''2'  'oG  =  r*eDD  +  2*rD*0D' 

'a  =  V(ar'^2  +  ae'^2)'  }  PEQ 


An  explanation  of  the  variables  follows: 

SOLVEP  =  a  program  that  triggers  the  multiple  equation  solver  for  the 
particular  set  of  equations  stored  in  variable  PEQ; 

NAME  =  a  variable  storing  the  name  of  the  multiple  equation  solver,  namely, 
"vel.  &  acc.  polar  coord. "; 

LIST  =  a  list  of  the  variable  used  in  the  calculations,  placed  in  the  order 
we  v/ant  them  to  show  up  in  the  multiple  equation  solver 
environment; 

PEQ  =  list  of  equations  to  be  solved,  corresponding  to  the  radial  and 
transverse  components  of  velocity  (vr,  v9)  and  acceleration  (ar, 
a9  )  in  polar  coordinates,  as  well  as  equations  to  calculate  the 
magnitude  of  the  velocity  (v)  and  the  acceleration  (a)  when  the 
polar  components  are  known. 

r,  rD,  rDD  =  r  (radial  coordinate),  r-dot  (first  derivative  of  r),  r-double  dot 

(second  derivative  of  r). 

GD,  0DD  =  0-dot  (first  derivative  of  0),  0-double  dot  (second  derivative  of  0). 


Suppose  you  are  given  the  following  information:  r  =  2.5,  rD  =  0.5,  rDD  =  - 
1 .5,  0D  =  2.3,  0DD  =  -6.5,  and  you  are  asked  to  find  vr,  v0,  ar,  a0,  v,  and  a. 
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Start  the  multiple  equation  solver  by  pressing 


The  calculator 


produces  a  screen  labeled  ,  "vel.  &  acc.  polar  coord.",  that  looks  as  follows: 


l: 


i    r    II  rP  II  rPD  II        II  ^DD  II  ur  j 


To  enter  the  values  of  the  known  variables,  just  type  the  value  and  press  the 
button  corresponding  to  the  variable  to  be  entered.  Use  the  following 
keystrokes:  2.5  [  r  ]  0.5  [  rD  ]  1 .5        [  rDD  ]  2.3  [90  ]  6.5         [  GDD  ]. 

Notice  that  after  you  enter  a  particular  value,  the  calculator  displays  the 
variable  and  its  value  in  the  upper  left  corner  of  the  display.  We  have  now 
entered  the  known  variables.  To  calculate  the  unknowns  we  can  proceed  in 
two  ways: 

a)  .  Solve  for  individual  variables,  for  example,  [Jnj  [  vr  ]  gives  vr:  0.500. 

Press  [nxt}[  *-]  J  [  v0  ]  to  get  v0  :  5.750  ,  and  so  on.  The  remaining  results 
are  v:  5.77169819031;  or:  -14.725;  aG:  -13.95;  and  a: 
20.2836911089.;  or, 

b)  .  Solve  for  all  variables  at  once,  by  pressing  (.  <n  JiilHlji.  The  calculator  will 

flash  the  solutions  as  it  finds  them.  When  the  calculator  stops,  you  can 
press  L  r»  jEEEi  to  list  all  results.  For  this  case  we  have: 


vsl.  &  111.  p*lor  c**rd. 


yr:  .5 


ye:  5.75 

y:  5.77169S19031 

ar:  -14.725 

ae:  -13.95 

a:   20.233691 1039 


Pressing  the  soft-menu  key  OSIjlli  will  let  you  know  the  equations  used  to 
solve  for  each  of  the  values  in  the  screen: 


yr:  yr=rD 


ye:  'ye=r*eD' 
y:    '  y=-J"tyr-^2.  -Hye-^2.  > ' 
ar:    '  ar=rDD-r*eD-^2.  ' 
ae:  'ae=r*eDD-H2.*rD*... 
a:    'a=Ttar-^2.-Hae-^2.  V 


VALUE  E4nS"  PRinT 
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To  use  a  new  set  of   values  press,  either  lu^zli  K3M[nxt )[nxt } ^  or 


Let's  try  another  example  using  r  =  2.5,  vr  =  rD  =  -0.5,  rDD  =  1 .5,  v  =  3.0,  a 
=  25.0.  Find,  9D,  9DD,  v9,  ar,  and  a6.  You  should  get  the  following  results: 


yr:  -.5 


ye :  £ . 95S039S? 1 55 
eDj    1. 1S321595662 

ael  -24.919S715SSS 
eDD:  -9.4946622529 


ivil.  &  ICC.  p*lor  c**rd. 


ye: 
eD: 
ar: 
ae: 

eDDi 


yr=rD 


'y=-rtyr-^2.+ye-^2... 
' ye=r*eD ' 
'  ar=rDD-r*eD-^2.  ' 
'a=-J"tar-^2.+ae-^2... 
'ae=r*eDD+2.*rD.. 


VALUE  E4nS"  PRinT 
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Chapter  8 

Operations  with  lists 

Lists  are  a  type  of  calculator's  object  that  can  be  useful  for  data  processing 
and  in  programming.  Tfiis  Chapter  presents  examples  of  operations  with  lists. 

Definitions 

A  list,  within  the  context  of  the  calculator,  is  a  series  of  objects  enclosed 
between  braces  and  separated  by  spaces  (I  sfc  j  ),  In  the  RPN  mode,  or 

commas  (QiD  ; ),  in  both  modes.  Objects  that  can  be  included  in  a  list  are 

numbers,  letters,  character  strings,  variable  names,  and/or  operators.  Lists 
are  useful  for  manipulating  data  sets  and  in  some  programming  applications. 
Some  examples  of  lists  are: 

i"    _      ._      _      .„  'I         :■       J-    4      .~i    —I  -I       I-  -"1  ^    -t       I-    4  —I  'i  "i 

■'.  d  -Id  d  -Id  .'■  ,  \    ■'.  1   ill  .D  /   \  I!'  iC   J.  .'■   ■'.  1   ill  I>  y  S 

In  the  examples  shown  below  we  will  limit  ourselves  to  numerical  lists. 

Creating  and  storing  lists 

To  create  a  list  in  ALG  mode,  first  enter  the  braces  key  [  <n  JU   (associated 

with  the  L  +  J  key),  then  type  or  enter  the  elements  of  the  list,  separating  them 

with  commas  (C2D  !  )•   The  following  keystrokes  will  enter  the  list  {1  2  3  4} 

and  store  it  into  variable  LI . 

The  screen  will  show  the  following: 


C  1 ,  2j3,  42>L  1  

 g.  2.  3.  4.} 

+^KIP|SKIP-H  H)EL  1  DEL-f|DEL  L|  inS  ■ 

+^KIP|SKIPH  H)EL  1  DEL-f|DEL  L|  inS  ■ 

The  figure  to  the  left  shows  the  screen  before  pressing  (wth),  while  the  one  to 
the  right  shows  the  screen  after  storing  the  list  into  LI .  Notice  that  before 
pressing  \fma\  the  list  shows  the  commas  separating  its  elements.  However, 
after  pressing  W^) ,  the  commas  are  replaced  with  spaces. 

Entering  the  same  list  in  RPN  mode  requires  the  following  keystrokes: 
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(d™)  (3  QD  (^s)  CD  droT) 
The  figure  below  shows  the  RPN  stock  before  pressing  the  [sto)  key: 


2: 

{1.  2.  3. 

4.} 

l: 

1 

LI ' 

TRIHni HE^l 

SIRS  1  PROJ  1  GRflV  1 

PIPE 

Composing  and  decomposing  lists 

Composing  and  decomposing  lists  mokes  sense  in  RPN  mode  only.  Under 
such  operating  mode,  decomposing  a  list  is  achieved  by  using  function 
OBJ^.  With  this  function,  a  list  in  the  RPN  stack  is  decomposed  into  its 
elements,  with  stack  level  1 :  showing  the  number  of  elements  in  the  list.  The 
next  two  screen  shots  show  the  stack  with  a  small  list  before  and  after 
application  of  function  OBJ^: 


4: 

4: 

3 

3: 

3: 

-2 

2: 

2: 

0 

1 :                         {3-2  0} 

l: 

3. 

EC   1  Hpor  |LVHRI|TITLE|    0    |    b  | 

■    EC   1  Hpor  |LVHRI|TITLE|    0    |  b 

Notice  that,  after  applying  OBJ^,  the  elements  of  the  list  occupy  levels  4: 
through  2:,  while  level  1 :  shows  the  number  of  elements  in  the  list. 


To  compose  a  list  in  RPN  mode,  place  the  elements  of  the  list  in  the  stack, 
enter  the  list  size,  and  apply  function  ^LIST  (select  it  from  the  function 
catalog,  as  follows:  [    J  cat  [    J  — ^  ,  then  use  the  up  and  down  arrow  keys 
((^^  Vt^  )  to  locate  function  ^LIST).  The  following  screen  shots  show  the 


elements  of  a  list  of  size  4  before  and  after  application  of  function 

5'  ■    ~  ■ 

5 
4 
3: 
2 
1 


ST: 


Note:  Function  OBJ^  applied  to  a  list  in  ALG  mode  simply  reproduces  the 
list,  adding  to  it  the  list  size: 


0BJ-*({3  2  -1» 


{3  2  -1  3.) 


I  Mpor  ILVflRIITITLEI 
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Operations  with  lists  of  numbers 

To  demonstrate  operations  with  lists  of  numbers,  we  will  create  a  couple  of 
otfier  lists,  besides  list  LI  created  above:  L2={-3,2, 1 ,5},  L3={-6,5,3, 1,0,3,-4}, 
L4={3,-2, 1 ,5,3,2, 1 }.  In  ALG  mode,  the  screen  will  look  like  this  after  entering 
lists  L2,  L3,  L4:   


{-3  2  1  5}frL2 

{-3  2  1  5} 
{-65  3  1  03  -4>frL3 

{-653  1  03  -4} 
{3  -2  1  5  32  1}¥L4 

{3-2  1  532  1} 


Ll    TRIHn  HE^l 


In  RPN  mode,  the  following  screen  shows  the  three  lists  and  their  names  ready 
to  be  stored.  To  store  the  lists  in  this  case  you  need  to  press  [sto]  three  times. 

Changing  sign 

The  sign-change  key  (I  *i-  J ) ,  when  applied  to  a  list  of  numbers,  will  change 


:L1 

{1. 

2.  3.  4.} 

:-Ll 

{-1.  -2. 

z3.  -4.} 

msmm 

ITRIHni  HE^l 

Addition,  subtraction,  multiplication,  division 

Multiplication  and  division  of  a  list  by  a  single  number  is  distributed  across  the 
list,  for  example: 


:  -5.L2 

{15  -10  -5  -25} 

.Ll 

■  5 

{.2.4.6.3} 

LH   1   Ll   ITRIHni  HE^l 

Subtraction  of  a  single  number  from  a  list  will  subtract  the  same  number  from 
each  element  in  the  list. 


or  examp 

le: 

:L2 

{-3  2  1  5} 

:L2-10 

{- 

-13. 

-3.  z?-  z5.} 

mSMMSM 

Ll  ITRIHRIHE^l 
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Addition  of  a  single  number  to  a  list  produces  a  list  augmented  by  the 
number,  and  not  an  addition  of  tfie  single  number  to  eacfi  element  in  tfie  list. 
For  example: 


:L1 

a  2  3  4} 

:Ll+6 

a_2  3  4  6} 

LH   1   LI  |TRIHn|HE£l 

Subtraction,  multiplication,  and  division  of  lists  of  numbers  of  tfie  same  lengtfi 


L1-L2 
L1.L2 


{4.  0.  2.  -1 
{-3.  4.  3.  20. }| 


Ll    TRIHn  HE^l 


{4.  0.  2.  -1.) 

:L1.L2 

{-3.  4.  3.  20.) 

.Ll 

■L2 

333333333333,1.  3.  .  ► 

LH   1   Ll  |TRIAn|HE£l 

Tfie  division  L4/L3  v/ill  produce  an  infinity  entry  because  one  of  tfie  elements 
in  L3  is  zero: 


.L4 

■L3 

-1  -2 

1 

1 

2  5 

3 

msmms 

■nu 

Ll 

ITRIAni  HE^l 

If  tfie  lists  involved  in  tfie  operation  fiave  different  lengtfis,  an  error  message  is 
produced  (Error:  Invalid  Dimension). 

Tfie  plus  sign  (I  +  J ),  when  applied  to  lists,  acts  a  concatenafion  operator, 
putting  together  the  two  lists,  rather  than  adding  them  term-by-term.  For 
example: 


L1-HL2 


{1  2  3  4-32  1  5) 


Ll    TRIAR  HE^l 


In  order  to  produce  term-by-term  addition  of  two  lists  of  the  some  length,  we 
need  to  use  operator  ADD.  This  operator  can  be  loaded  by  using  the  function 
catalog  ([    J  cat  ).  The  screen  below  shows  on  application  of  ADD  to  add 
lists  Ll  and  L2,  term-by-term: 


Ll  RDD  L2 


{-2  4  4  9) 


Ll    TRIAR  HE^l 


Page  8-4 


Real  number  functions  from  the  keyboard 

Real  number  functions  from  the  keyboard  (ABS,  e^  LN,  1 0^  LOG,  SIN,  V, 
COS,  TAN,  ASIN,  ACOS,  ATAN,  y'')  can  be  used  on  lists.  Here  are  some 
examples: 


ABS 


:L2 

{-3  2  1  5} 

:IL£I 

 i3  2  1  5} 

LH   1   LI  |TRIAn|HE£l 

EXP  and  LN 


I  1    2   3  41 

:LH(L1) 

{0  LH(2)  LH(3)  2.LH(2)}| 


Ll    TRinn  HE^l 


LOG  and  ANTILOG 


:L0G(L1) 

{0  L0G(2)  LOGO)  L0G(4)}| 
:RL0G(L£) 

100  10  100000 


Ll    TRIAn  HE^l 


SO  and  square  root 


:SQ(L1) 

a  4  9  16} 

:  JL2 

{■FT-Js  -12  1  E] 

LH   1   Ll  ITRIARIHE^l 

SIN,  ASIN 


SIH(Ll) 
KSIH(l)  SIH(2)  SIH(3)  SIHH 

. 3046926540 1 5  . 20 1 35  H 


Ll    TRIAR  HE^l 


COS,  ACOS 


C0S(L2) 

KC0S(3)  C0S(2)  COS(l)  COSt^H 

RC0S[^] 
K1.47062S90563  1.36943H 


Ll    TRIAR  HE^l 


AN,  ATAN 


TflH(Ll) 
^TRH(l)  TRH(2)  TRH(3)  TRHt^H 
iRTRH(L2) 

-RTRH(3)  flTflH(2)  ^  RTRHCH 


Ll    TRIAR  HE^l 


INVERSE  (1/x 


Real  number  functions  from  the  MTH  menu 

Functions  of  interest  from  the  MTH  menu  include,  from  the  HYPERBOLIC  menu: 
SINH,  ASINH,  COSH,  ACOSH,  TANH,  ATANH,  and  from  the  REAL  menu:  %, 
%CH,  %T,  MIN,  MAX,  MOD,  SIGN,  MANT,  XPON,  IP,  FP,  RND,  TRNC, 
FLOOR,  CEIL,  D^R,  R^D.  Some  of  the  functions  that  take  a  single  argument 
are  illustrated  below  applied  to  lists  of  real  numbers: 
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SINH,  ASINH 


:SIHH(L1) 

{SIHHtD  SIHH(£)  SIHH(3)  S> 
:RSIHh[^] 

{-.295673047563  . 19369 ► 


£inH      inH  CO^H  HCO^H  THnH  HTHnH 


TANH,  ATANH 


TRHH(L2) 
^-TRHH(35  TRHH(2)  TRHH(l)  H 

RTRHH(Ll) 
kRTRHH(15  RTRHH(2)  RTRHHtH 


£inH      inH  CO^H  HCO^H  THnH  HTHnH 


COSH,  ACOSH 


C0SH(L2) 
^C0SHt3)  C0SH(2)  COSH(l)  CH 

RCOSH(Ll) 
k0  RC0SH(2)  flC0SH(3)  RCOSH 


£inH  Hf inn  co^h  hco^h  THnn  hthhh 


SIGN,  MANT,  XPON 


:  blLiHlLlJ 

a 

1 

1  IJ 

:MRHT(100.L2) 

{3. 

2. 

1. 

5.} 

:XPOH(LM00) 

{2. 

2. 

2. 

2.} 

HE^  1  £ian  1 HHHT 1  xpon 

1  I 

F-  1 

P,  FP 

FLOOR,  CEIL 

: IPK1.2  2.3 

-1.5» 

:FL00R({1.2  2.3  - 

a.  2.  -1.) 

a. 

2.  -2.) 

:FP({1.2  2.3 

-1.5}) 

:CEIL({1.2  £.3  -1 

.5}) 

{.2  .3  -.5) 

{2. 

3.  -1.) 

HE^  1         \  HHHT 

IP       FP  ^^^^^^H 

RHD  1  TRHC  IFLOORI  CEIL  | 

D^R,  R^D 


:D-*R({30  60  90}) 
.  52359S77559S  1.04719H 

^^^''llfif}) 

P0.  60.0000000002  90.  E> 


RHD    TRRC  FLOOR  CEIL  D-« 


Examples  of  functions  that  use  two  arguments 

The  screen  shots  below  show  applications  of  the  function  %  to  list  arguments. 
Function  %  requires  two  arguments.  The  first  two  examples  show  cases  in 
which  only  one  of  the  two  arguments  is  a  list.  


■■y.iilS  20  30},1) 

{.1  .2.3} 

i::(5,a0  20  30}) 
,  r  10  ^  5  ^  10J 

The  results  are  lists  with  the  function  %  distributed  according  to  the  list 
argument.  For  example. 
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%({!  0,  20,  30},  1 )  =  {%(1 0, 1  ),%(20, 1  ),%(30, 1 )}, 

while 

%(5,{1 0,20,30})  =  {%(5,10),%(5,20),%(5,30)} 


In  the  following  example,  both  arguments  of  function  %  are  lists  of  the  same 
size.  In  this  case,  a  term-by-term  distribution  of  the  arguments  is  performed, 
i.e., 

%({10,20,30},{1,2,3})  =  {%(10,1),%{20,2),%{30,3)} 


■.y.i.{.lQ  20  30M1  2  3» 
^{■■iH!iwfi;H«i;MM;H<^ 

This  description  of  function  %  for  list  arguments  shows  the  general  pattern  of 

evaluation  of  any  function  with  two  arguments  when  one  or  both  arguments 
are  lists.  Examples  of  applications  of  function  RND  are  shown  next; 


:RHD 

{.33  . 17  .33} 

:RHD 

^.{2  3  4>) 

{.33  .333  .3333} 

inTEGI 

POLV  IHODULI  PERM  |DIVIS|FflCTO 

Lists  of  complex  numbers 

The  following  exercise  shows  how  to  create  a  list  of  complex  numbers  given 
two  lists  of  the  same  length,  one  representing  the  real  parts  and  one  the 
imaginary  parts  of  the  complex  numbers.  Use  LI  ADD  i*L2.  The  screen  also 
shows  that  the  resulting  complex-number  list  is  stored  into  variable  L5: 


LI  i  L2  RDD  * 

{l-Hi-3  2-Hi.2  3-Hi  4-Hi.5} 
RHS(l)frL5 

{l-Hi-3  2-Hi.2  3-Hi  4-Hi.5} 


Functions  such  as  LN,  EXP,  SQ,  etc.,  can  also  be  applied  to  a  list  of  complex 
numbers,  e.g.. 
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SQ(L5) 

KSQ(l  +  i-3)  SQ(2+i.25  SQ(3-H 
[[3+i)-J2-2'i-J5)-Jl+JTs"  Q^ 


r^l.i.-3 

2+i-2   3+i  4+\ 

e         e  e 

:  LH(L5) 

tLH(l  +  i- 

3)  LH(2+i.2)  LH(3-> 

:  MLULilLDJ 

^RL0G(l  +  i-3)  RL0G(£+i-2)  H 

L0G(L5) 
KL0G(l  +  i-3)  L0G(2+i.2)  LOH 

IHV(L5) 

1  1 


3  2+i-2  3+i  4+ 


:SIH(L5) 

tSIH(l  +  i-3)  SIH(2+i.2)  SIH 
:SIHH(L5) 

tSIHHa  +  i-3)  SIHH(2+i'2)  H 
:RSIH(L5) 
tRSIHtl  +  i-3)  RSIH(2+i.2)  H 


The  following  example  shows  applications  of  the  functions  RE(Real  part), 
IM(imaginary  part),  ABS(magnitucle),  and  ARG(argument)  of  complex 
numbers.  The  results  are  lists  of  real  numbers: 


:RE(L5) 

{1  2  3  4} 

:  IM(L5) 

{-3  2  1  5} 

:IL5I 

{■M  2-J2  -fTe  J41} 

■OHO 

:  RRG(L5) 

[-RTRH(35 

^  RTflH[- 

11  flTRH[( 

Ll  ITRIfln 

Lists  of  algebraic  objects 

The  following  are  examples  of  lists  of  algebraic  objects  with  the  function  SIN 
applied  to  them: 


Ll  TRIHn 


SIHtRHStD) 


I2  ""^  4~j 


1^  g-p  ]         {sIh[^]  SIH(o:-p)  SIH 


4 


Ll  TRIHn 


The  MTH/LIST  menu 

The  MTH  menu  provides  a  number  of  functions  that  exclusively  to  lists.  With 
flag  n  7  set  to  CHOOSE  boxes: 
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HHTH  HEnU 

1.  VECTOR..  1 

2.  HATRIK.. 

3.  LIST.. 

H.HYPEREOLIC. 
5.  REAL.. 
e.EASE.. 

1       1       1  IcflncL 

OK 

LIST  HERU 


a.ELIST 

3.m.IST 

H.SORT 

5.REVLIST 

e.ADD 


Next,  with  system  flag  1 1 7  set  to  SOFT  menus: 


This  menu  contains  the  following  functions: 


Calculate  increment  among  consecutive  elements  in  list 
Calculate  summation  of  elements  in  the  list 
Calculate  product  of  elements  in  the  list 
Sorts  elements  in  increasing  order 
Reverses  order  of  list 

Operator  for  term-by-term  addition  of  two  lists  of  the  same  length 


ALIST 
ILIST 
nUST 
SORT 
REVLIST 
ADD 

(examples  of  this  operator  were  shown  above) 
Examples  of  application  of  these  functions  in  ALG  mode  ore  shown  next: 


:L3 

6 

5  3  1 

0  3 

-4} 

:iLIST(L3) 

ai 

2  -2  - 

-1  3 

-7} 

iLIST|ELIST|m.IST| 

SORT  IREVLII 

ADD 

:L3 

6 

5  3  1 

0  3 

-4} 

:S0RT(L3) 

i- 

6 

-4  0 

1  3 

3  5} 

iLIST|ELIST|m.IST| 

SORT  IREVLII 

ADD 

L3 


2LIST(L3) 


L3 


{-653  1  03  -4} 


{-653  1  03  -4} 
REVLIST(L3) 

{-430  1  35  -6} 


SORT  and  REVLIST  can  be  combined  to  sort  a  list  in  decreasing  order: 


L3 

{-653  1  03  -4}^ 
REVLISTtS0RT(L3)) 

{533  1  0  -4  -6}] 


iLIST  ELIST  m-IST  SORT  REVLI  ADD 
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Manipulating  elements  of  a  list 

The  PRG  (programming)  menu  includes  a  LIST  sub-menu  with  a  number  of 
functions  to  manipulate  elements  of  a  list.   With  system  flag  1 1  7  set  to 
CHOOSE  boxes: 


PROG  HEnU 

1.  JTflCK..  1 

2.  HEH0RY.. 
^.RRflnCH.. 
H.TEST.. 
5.  TYPE.. 

e.LIST..  1 

ICflnCL 

OK 

LIST  HERU 

l.ELEMEnTS..  II 

2. PROCEDURES..  1 

J.OS-l*  1 

H.-H.IST  1 

5. SUP  1 

e.REPL  D 

1      1      1  IcflnoT 

OK 

item  1 .  ELEMENTS.,  contains  the  following  functions  that  can  be  used  for  the 


manipu 


ation  of  elements  in  lists: 


ELEHERT  HERU 

2.  CETI 

3.  PUT 
H.PUTI 
5. SIZE 

e.pos 

ELEHERT  HERU 

H.PUTI 

5. SIZE 

S.POS 

Z.HEflD 

S.TAIL 

S.LIST.. 

J 

1      1      1  IcfliiciT 

OK 

List  size 

Function  SIZE,  from  the  PRG/LIST/ELEMENTS  sub-menu,  can  be  used  to 
obtain  the  size  (also  known  as  length)  of  the  list,  e.g.. 


L3 
SIZE(L3) 


{-653  1  03  -4} 


Extracting  and  inserting  elements  in  a  list 

To  extract  elements  of  a  list  we  use  function  GET,  available  in  the 
PRG/LIST/ELEMENTS  sub-menu.  The  arguments  of  function  GET  are  the  list 
and  the  number  of  the  element  you  want  to  extract.  To  insert  an  element  into 
a  list  use  function  PUT  (also  available  in  the  PRG/LST/ELEMENTS  sub-menu). 
The  arguments  of  function  PUT  are  the  list,  the  position  that  one  wants  to 
replace,  and  the  value  that  will  be  replaced.  Examples  of  applications  of 
functions  GET  and  PUT  are  shown  in  the  following  screen: 


GET(L3,5) 


0 


PUT(L3,5.10) 

^-6  5  3  1  10  3  -4} 


Ll  TRIflR 
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Functions  GETI  and  PUTI,  also  available  in  sub-menu  PRG/  ELEMENTS/,  can 
also  be  used  to  extract  and  place  elements  in  a  list.  These  two  functions, 
however,  are  useful  mainly  in  programming.  Function  GETI  uses  the  same 
arguments  as  GET  and  returns  the  list,  the  element  location  plus  one,  and  the 
element  at  the  location  requested.  Function  PUTI  uses  the  same  arguments  as 
GET  and  returns  the  list  and  the  list  size. 


Element  position  in  the  list 

To  determine  the  position  of  an  element  in  a  list  use  function  POS  having  the 
list  and  the  element  of  interest  as  arguments.  For  example, 


:L3 

-6  5  3 

10  3-4} 

:P0S(L3,5) 

  2. 

■na 

Ll  ITRIAn 

HEAD  and  TAIL  functions 

The  HEAD  function  extracts  the  first  element  in  the  list.  The  TAIL  function 
removes  the  first  element  of  a  list,  returning  the  remaining  list.  Some  examples 
are  shown  next: 


:L3 

{-653103 

-4} 

:HERD(L3) 

-6 

:TflIL(L3) 

{53103 

-4} 

The  SEQ  function 

Item  2.  PROCEDURES.,  in  the  PRG/LIST  menu  contains  the  following  functions 
that  can  be  used  to  operate  on  lists. 


PROC  HEnu 

l.DOLIJT  II 

2.D0SURS  1 

?.nsuR  1 
H.EnDsue  1 

5. STREAM 

e.REVLIST  W 

1    1  1 

ICAnCLl 

OK 

RROC  HERU 

H.ERDSUR 

5. STREAM 

S.REVLIST 

?.SORT 

S.SEC 

S.LIST.. 

J 

ICARCLl 

OK 

Functions  REVLIST  and  SORT  were  introduced  earlier  as  part  of  the  MTH/LIST 
menu.  Functions  DOLIST,  DOSUBS,  NSUB,  ENDSUB,  and  STREAM,  are 
designed  as  programming  functions  for  operating  lists  in  RPN  mode.  Function 
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SEQ  is  useful  to  produce  a  list  of  values  given  a  particular  expression  and  is 
described  in  more  detail  fiere. 


Tfie  SEQ  function  takes  as  arguments  an  expression  in  terms  of  an  index,  the 
name  of  the  index,  and  starting,  ending,  and  increment  values  for  the  index, 
and  returns  a  list  consisting  of  the  evaluation  of  the  expression  for  all  possible 
values  of  the  index.  The  general  form  of  the  function  is  SEQ{express/on,  index, 
start,  end,  incremenf). 


In  the  follov/ing  example,  in  ALG  mode,  v/e  identify  expression  =  n^,  index 
n,  start  =  1 ,  end  =  4,  and  increment  =  1 : 


SEQ(n^",n,1..4.  .1.) 


■{V.  '4.  9.  16.} 


The  list  produced  corresponds  to  the  values  {P,  2^,  3^,  4^}.  In  RPN  mode, 
you  can  list  the  different  arguments  of  the  function  as  ollov/s: 


5: 

2. 

n 

4: 

'n' 

3: 

1. 

Z: 

4. 

l: 

1. 

SORTI  SE4  1         1         1  ILIST 

before  applying  function  SEQ. 


The  MAP  function 

The  MAP  function,  available  through  the  command  catalog  ((j^l  cat  takes 
as  arguments  a  list  of  numbers  and  a  function  f(X)  or  a  program  of  the  form 
«  ^  a  ...  »,  and  produces  a  list  consisting  of  the  application  of  function  f 
or  the  program  to  the  list  of  numbers.    For  example,  the  follov/ing  call  to 
function  MAP  applies  the  function  SIN(X)  to  the  list  {1,2,3}: 


MRPKl  2  3}.SIHtX)) 

{SIHdi  SIH(2)  SIH(3)} 


CflSCM  HELP 


The  follov/ing  call  to  function  MAP  uses  a  program  instead  of  a  function  as 
second  argument: 


-2-1 '  s-> 

{-1  0  3}^ 


CflSCM  HELP 
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Defining  functions  that  use  lists 

In  Chapter  3  we  introduced  the  use  of  the  DEFINE  function  ( L  ^  J )  to 
create  functions  of  real  numbers  with  one  or  more  arguments.  A  function 
defined  with  DBF  can  also  be  used  with  list  arguments,  except  that,  any 
function  incorporating  an  addition  must  use  the  ADD  operator  rather  than  the 
plus  sign  ([  +  J).  For  example,  if  we  define  the  function  F(X,Y)  =  (X-5)*(Y-2), 
shown  here  in  ALG  mode: 


DEFIHE('F(X,Y)=tX-5.  MY-^ 
HOVRL 


we  can  use  lists  (e.g.,  variables  LI  and  L2,  defined  earlier  in  this  Chapter)  to 
evaluate  the  function,  resulting  in: 


DEFIHE('F(X,Y)=tX-5.  MY-^ 
HOVRL 

F(L1,L2) 

{20.  0.  £.  -3.} 


Since  the  function  statement  includes  no  additions,  the  application  of  the 
function  to  list  arguments  is  straightforward.  However,  if  we  define  the 
function  G(X,Y)  =  (X+3)*Y,  an  attempt  to  evaluate  this  function  with  list 
arguments  (LI,  L2)  will  fail: 


:DEFIHE('G(X,Y)=tX+3.m 
HOVRL 

G(L1,L2> 

:DE 

A  *  Error: 
Inyal id 
Dimension 

n 

VRL 

:G(Li.L^j 

"Invalid  Dimension" 

To  fix  this  problem  we  can  edit  the  contents  of  variable 
list  in  the  stack  by  using  [  Jllljljlll, 


,  which  we  can 


DEFIHE('G(X,Y)=tX+3.m 
HOVRLJ 

G(L1.L2) 

" I nya lid  D  i  mens  i  on " 
■£      X  Y  '  tX+3.  >*Y'  s^ 


to  replace  the  plus  sign  (+)  with  ADD: 
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G(L1.L2) 

" I nya lid  D  i  mens  i  on " 
■£      X  Y  '  >*Y'  :* 

■£      X  Y   '  tX  RDD  3. 

V  s- 

*:  +  X  Y   '  tX  RDD  3.  >*Y' 


+^KIP  SKIP-H  H)EL   DEL-f  DEL  L  inS  i 


Next,  we  store  the  edited  expression  into  variable  II 


X  Y  'CX  ADD 

3.  >* 

V  s- 

*:  +  X 

Y  ' tX  RDD  3. 

>*Y' 

:RHS(1 

*:  +  X 

Y  ' tX  RDD  3. 

>*Y' 

Evaluating  G(L1,L2)  now  produces  the  following  result: 


G(L1,L2) 


{-12.  10.  6.  35.} 


As  on  alternative,  you  can  define  the  function  with  ADD  rather  than  the  plus 
sign  (+),  from  the  start,  i.e.,  use  DEFINE';  '  GC<,  •■r^  =  CA  RDD  BiJSV  '  > 


DEFIHE('G(X,Y)=tX  RDD  3> 
HOVRL 

G(L1,L2) 

{-12.  10.  6.  35.} 


You  can  also  define  the  function  as  G(X,Y)  =  (X-3)*Y. 


Applications  of  lists 

This  section  shows  a  couple  of  applications  of  lists  to  the  calculation  of 
statistics  of  a  sample.  By  a  sample  we  understand  a  list  of  values,  say,  {s,, 
S2,      s^}.   Suppose  that  the  sample  of  interest  is  the  list 

!■    ■!  C         "-t  i  ■!  ""I  .■!  •■"1  H  -I 

'■.    1  ■■      _■  ■■      Zi  ■■       1  ■■      ill.  ■■       J.  H      3  H      *-■*  |l  |l       J.  .1' 
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and  that  we  store  it  into  a  variable  called  S  (The  screen  shot  below  shows  this 
action  in  ALG  mode,  however,  the  procedure  in  RPN  mode  is  very  similar. 
Just  keep  in  mind  that  in  RPN  mode  you  place  the  arguments  of  functions  in 
the  stack  before  activating  the  function):  


^l.  5.  3.  1.  a.  1.  3.  H.  a.  i.j 
^l.  5.  3.  1.  a.  1.  3.  H.  a.  i.: 


+^KIP  SKIP-H  *OZL   DEL-f  DEL  L  inS  i 


Harmonic  mean  of  a  list 

This  is  a  small  enough  sample  that  we  can  count  on  the  screen  the  number  of 
elements  (n=l  0).  For  a  larger  list,  we  can  use  function  SIZE  to  obtain  that 
number,  e.g.. 


:a.  5.  3.  1 

.  2.  1 

.  3.  4.  ► 

(1.  5.  3.  1. 

2.  1. 

3.  4. 

:SIZE(S) 

10. 

Suppose  that  we  want  to  calculate  the  harmonic  mean  of  the  sample,  defined 
as 

1  1 


1     n  1 


1      1  1 

-  +  —  +  •••  +  — 
s 


n  J 


To  calculate  this  value  we  can  follow  this  procedure: 
1 .   Apply  function  INV  ()  to  list  S:  


a.  5.  3.  1.2.  1.  3.  4.  ► 
Kl.  5.  3.  1.  2.  1.  3.  4.  2> 

SIZE(S) 

10 

IHV(S) 

Kl.  .2  .333333333333  1.  H 


2.   Apply  function  SLISTQ  to  the  resulting  list  inl . 

Kl.  5.  3.  1.  2.  1.  3.  4.  ;H 


SIZE(S) 


10. 


IHV(S) 

Kl.  .2  .333333333333  1.  H 
SLISTtRHSd.)) 

6.  1166666666^^ 


iLIST  ELIST  m-IST  SORT  REVLI  HDD 
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3.   Divide  the  result  above  by  n  =  10: 
i:  iNViiJ 

(1.  .2  .333333333333  1.  H 
iSLISTtflHSdJ) 

.  RHStl.) 


10. 


.611666666666 


4.   Apply  the  INVQ  function  to  the  latest  result: 

F  iLli  I  IMNiU  .  JJ 


6.  1166666666^^ 

RHStl.) 

10. 

.61166666666^^ 
IHVtRHSd.)) 

1 . 634S773S42j 


Thus,  the  harmonic  mean  of  list  S  is  Sh  =  1 .6348... 

Geometric  mean  of  a  list 

The  geometric  mean  of  a  sample  is  defined  as 

V  k=\ 

To  find  the  geometric  mean  of  the  list  stored  in  S,  v/e  can  use  the 
following  procedure: 


1 .   Apply  function  nL 


STQ  to  list  S: 


■  10. 

.611666666666 

:  IHVtRHSd 

1 . 634S773S42 

iTTLISTtS) 

720. 

2.   Apply  function  XROOT(x,y),  i.e.,  keystrokes  I  r>  ]^n, ,  to  the  result  in 


.61166666666^^ 
IHVtRHStl.)) 

1 . 634S773S42j 

TTLISTtS) 

720 

™OTtRHS(l>,  10)4 


.  bl  IbbbbbbbbbI 
IHVtRHStl.)) 

1 . 634S773S42j 

TTLISTtS) 

720 

RHStl.  ).n^ 

1.003203154021 


Thus,  the  geometric  mean  of  list  S  is  Sg  =  1 .003203... 
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Weighted  average 

Suppose  that  the  data  in  list  S,  defined  above,  namely: 


'!      ^  J.     ™'  ^  ■"!•  ^  ill  1  1  .'■ 


is  affected  by  the  weights, 


If  we  define  the  weight  list  as  W  =  {wi,W2,...,Wn},  we  notice  that  the  /c-th 
element  in  list  W,  above,  con  be  defined  by  W|<  =  k.  Thus  we  can  use  function 
SEQ  to  generate  this  list,  and  then  store  it  into  variable  SEIS  as  follows: 


1.003203154021 

SEQ(k,k,1..10..1.) 
Kl.  2.  3.  4.  5.  6.  7.  S.  'itl 

RHSdJUJ 
Kl.  2.  3.  4.  5.  6.  7.  3.  'itl 


Given  the  data  list  {si,  S2,  s„  },  and  the  weight  list  {wi,  W2,  w^ },  the 
weighted  average  of  the  data  in  S  is  defined  as 


s,.. 


■ 


w  „ 


k=l 


To  calculate  the  weighted  average  of  the  data  in  list  S  with  the  weights  in  list 
W,  we  can  use  th  e  following  steps: 


1.   Multiply  lists  S  and  W: 

I  1.003203154021 
:SEQ(k,k, 1.40.4.) 
(1.  2.  3.  4.  5.  6.  7.  3. 
:RHS(1.)HJ 

(1.  2.  3.  4.  5.  6.  7.  3. 
(1.  10.  9.  4.  10.  6.  21. 


Use  function  SLIST  in  this  result  to  calculate  the  numerator  of 


2.  3.  4.  5.  6.  7.  3. 

RH3(1.)HJ 
Kl.  2.  3.  4.  5.  6.  7.  3. 

3.W 

Kl.  10.  9.  4.  10.  6.  21.  H 

2LI3T(RH3(1.)) 

121 


iLIST  ELIST  m-IST  SORT  REVLI  HDD 
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3.   Use  function  SLIST,  once  more,  to  calculate  the  denominator  of  s^: 


(1.  2.  3.  4.  5.  6. 

7.  3.  'it 

(1.  10.  9.  4.  10. 

6.  21.  ► 

:2LIST(RHS(1.)) 

121. 

iSLISTtW) 

55. 

Use  tfie  expression  ANS(2)/ANS(1 )  to  calculate  the  weighted 
average: 


:  iLli  1  IMNill  .  JJ 

121. 

iSLISTtW) 

55. 

.  flHS(2.) 

■  RHSd.) 

2.2 

Thus,  the  weighted  average  of  list  S  with  weights  in  list  W  is  5^,=  2.2. 


Note:  ANS{1)  refers  to  the  most  recent  result  (55),  while  ANS(2)  refers  to 
the  previous  to  last  result  (121). 


Statistics  of  grouped  data 

Grouped  data  is  typically  given  by  a  table  showing  the  frequency  (w)  of  data 
in  data  classes  or  bins.  Each  class  or  bin  is  represented  by  a  class  mark  (s), 
typically  the  midpoint  of  the  class.  An  example  of  grouped  data  is  shown 
next: 


Class 

Frequency 

Class 

mark 

count 

boundaries 

Sk 

Wk 

0-2 

1 

5 

2-4 

3 

12 

4-6 

5 

18 

6-8 

7 

1 

8-10 

9 

3 

The  class  mark  data  can  be  stored  in  variable  S,  while  the  frequency  count 
can  be  stored  in  variable  W,  as  follows: 
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SEQ(2.k-l,k, 1.5.1) 

{1  3  5  7  9} 

RHStDfrS 

{1  3  5  7  9} 

{5  12  IS  1  3}frW 

{5  12  IS  1  3} 


Given  the  list  of  class  marks  S  =  {s,,  S2,      s^ },  and  the  list  of  frequency 
counts  W  =  {wi,  W2,      Wn },  the  weighted  average  of  the  data  in  S  with 
weights  W  represents  the  mean  value  of  the  grouped  data,  that  we  call  s,  in 
this  context: 


s  = 


k=l 


k=l 


N 


k=\ 


where  ^  =  represents  the  total  frequency  count. 


The  mean  value  for  the  data  in  lists  S  and  W,  therefore,  can  be  calculated 

using  the  procedure  outlined  above  for  the  weighted  average,  i.e., 
I  i^j  1  oji 


SL I  SUN'S) 
SLISTtW) 

55 
13 

■^HUMtRHStD) 

4.230769230771 


We'll  store  this  value  into  a  variable  called  XBAR; 


55 
13 

■^HUMtRHStD) 

4.230769230771 
RHStDfrXBRR 

4.230769230771 


The  variance  of  this  grouped  data  is  defined  as 

n  n 


v  = 


k=l 


k=\ 


n 

I 

k=l 


N 
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To  calculate  this  last  result,  we  can  use  the  following: 


4.230769230771 
2LISt(w.(S-XBRR)^) 


SLISTtW) 


156.923076923 

39 


4.230769230771 
2LIStU(S-XBRR)^) 


SLISTtm 


156.923076923 

39 


The  standard  deviation  of  the  grouped  data  is  the  square  root  of  the  variance 

■  1  -J  I  KVii  — 


39 

.  RHS(2) 

■  RHS(l) 

4. 

02366S63905 

:-JRHS(l) 

2. 

00590S43237 
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Chapter  9 
Vectors 

This  Chapter  provides  examples  of  entering  and  operating  with  vectors,  both 
mathematical  vectors  of  many  elements,  as  well  as  physical  vectors  of  2  and  3 
components. 

Definitions 

From  a  mathematical  point  of  view,  a  vector  is  an  array  of  2  or  more  elements 
arranged  into  a  row  or  a  column.   These  will  be  referred  to  as  row  and 
column  vectors.  Examples  are  shown  below: 

r 


V  = 


3 
6 


u  =  [1,-3,5,2] 


Physical  vectors  have  two  or  three  components  and  can  be  used  to  represent 
physical  quantities  such  as  position,  velocity,  acceleration,  forces,  moments, 
linear  and  angular  momentum,  angular  velocity  and  acceleration,  etc. 
Referring  to  a  Cartesian  coordinate  system  (x,y,z),  there  exists  unit  vectors  i,  j, 
k  associated  with  each  coordinate  direction,  such  that  a  physical  vector  A  can 
be  written  in  terms  of  its  components  A„  Ay,  A^,  as  A  =  A^i  +  Ayj  +  A^k. 
Alternative  notation  for  this  vector  are:  A  =  [A„  Ay,  AJ,  A  =  (A„  Ay,  AJ,  or  A 
=  <  A„  Ay,  A^  >.  A  two  dimensional  version  of  this  vector  will  be  written  as  A 
=  AJ  +  Ayi,  A  =  [A^,  Ay],  A  =  (A„  Ay),  or  A  =  <  A^,  Ay  >.  Since  in  the 
calculator  vectors  are  written  between  brackets  [  ],  we  will  choose  the  notation 
A  =  [A^,  Ay,  A^]  or  A  =  [A,,,  Ay,  A^],  to  refer  to  two-  and  three-dimensional 
vectors  from  now  on.   The  magnitude  of  a  vector  A  is  defined  as  j  Aj  = 

■^JaI  +      +  a]  .  A  unit  vector  in  the  direction  of  vector  A,  is  defined  as  eA  = 

A/jAj .  Vectors  can  be  multiplied  by  a  scalar,  e.g.,  kA  =  [kA„  kAy,  kAJ. 
Physically,  the  vector  kA  is  parallel  to  vector  A,  if  k>0,  or  anti-parallel  to 
vector  A,  if  k<0.  The  negative  of  a  vector  is  defined  as  -A  =  (-1  )A  =  [-A„  - 
Ay,  -AJ.  Division  by  as  scalar  can  be  interpreted  as  a  multiplication,  i.e., 
A/k  =  (1/k)  A.   Addition  and  subtraction  of  vectors  are  defined  as  A+B  =  [A^ 
±  B„  Ay+  By,  A,±  By],  w h e re  B  is  the  vector  B  =  [B„  By,  BJ. 


Page  9-1 


There  are  two  definitions  of  products  of  physical  vectors,  a  scalar  or  internal 
product  (the  dot  product)  and  a  vector  or  external  product  (the  cross  product). 
The  dot  product  produces  a  scalar  value  defined  as  A»B  =  |  A  |  |  B  |  cos(9), 
v/here  0  is  the  angle  between  the  two  vectors.  The  cross  product  produces  a 
vector  AxB  whose  magnitude  is  |AxB|  =  |A|  |B|sin(6),  and  its  direction  is 
given  by  the  so-called  right-hand  rule  (consult  a  textbook  on  Math,  Physics,  or 
Mechanics  to  see  this  operation  illustrated  graphically).    In  terms  of  Cartesian 
components,  A.B  =  A,B,+AyBy+A,B„  and  AxB  =  [AyB,-A,By,A,B,-A,B„A,By- 
AyBJ.  The  angle  between  two  vectors  can  be  found  from  the  definition  of  the 
dot  product  as  cos(6)  =  A»B/ 1  A|  |  B  |  =  eA»eB.  Thus,  if  two  vectors  A  and  B  are 
perpendicular  (0  =  90°  =  7t/2^°''),  A.B  =  0. 

Entering  vectors 

In  the  calculator,  vectors  are  represented  by  a  sequence  of  numbers  enclosed 
between  brackets,  and  typically  entered  as  row  vectors.  The  brackets  are 

generated  in  the  calculator  by  the  keystroke  combination  LjnJW   , 

associated  with  the  L  x  J  key.  The  following  are  examples  of  vectors  in  the 
calculator: 

C  3 «  5  J  £ .  2  J  —1.3?  15  „  6  ;i  £ «  3 !]    A  general  row  vector 

i:i„5;, -£.£:i  A  2-D  vector 

1:3  J -I,  2:1  A  3-D  vector 

L  '  ii, '  .1  '  iL.  ''"2  '  1  '  S  i  i-h:!  t- !:=  '  J  A  vector  of  algebraics 

Typing  vectors  in  the  stack 

With  the  calculator  in  ALG  mode,  a  vector  is  typed  into  the  stack  by  opening 

a  set  of  brackets  (L  <n  J (j  )  and  typing  the  components  or  elements  of  the 

vector  separated  by  commas  (I  r»  J  ; ).  The  screen  shots  below  show  the 

entering  of  a  numerical  vector  followed  by  an  algebraic  vector.  The  figure  to 
the  left  shows  the  algebraic  vector  before  pressing  [Jjj .  The  figure  to  the  right 
shows  the  calculator's  screen  after  entering  the  algebraic  vector: 


:  [5  3  -1  2  4] 

[5  3-1  2  4] 
[t-^2,s-2*t,Ta-34] 

:  [5  3  -1  2  4] 

[5  3-1  2  4] 
:[t^  s-2-t  -Jt-s] 

[t^  s-2.t  ■it-3] 
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In  RPN  mode,  you  con  enter  a  vector  in  the  stock  by  opening  a  set  of  brackets 
and  typing  the  vector  components  or  elements  separated  by  either  commas 

([    J  ; )  or  spaces  ([  spc)).  Notice  that  after  pressing  [inter]  ,  in  either  mode, 

the  calculator  shows  the  vector  elements  separated  by  spaces. 


Storing  vectors  into  variables 

Vectors  can  be  stored  into  variables.  The  screen  shots  below  show  the  vectors 

U2  =  L  1  J    i::  J  ,  U3  =  I.  —    J  .J  ,  V2  =  l.  .3  s  —  J.  J  ,  V3  =  I.  1  ;i    —.J  *  J 

stored  into  variables  lEEIil,  SS!liSI,  iSSiS,  and  SBS^I,  respectively.  First,  in  ALG 
mode: 


:[1  2>u2 

[1  2] 

:[-3  2  -2]fru3 

[-3  2  -2] 

Then,  in  RPN  mode  (before  pressing  [£g>J,  repeatedly) 


4: 
3: 
2: 
l: 


[1  2] 
'u2' 
[-3  2  -21 
'u3' 


[1  2] 

:  [-3  2  -2]fru3 

[-3  2  -2] 

:[3  -l]fry2 

[3  -1] 

:[1  -5  2]fry3 

[1  -5  2] 

,  repeatedly): 

4: 

[3  -1] 

3: 

'y2' 

2: 

[1  -5  2] 

l: 

'y3' 

Using  the  Matrix  Writer  (MTRW)  to  enter  vectors 

Vectors  can  also  be  entered  by  using  the  Matrix  Writer  [  <n  )mtrw  (third  key  in 
the  fourth  row  of  keys  from  the  top  of  the  keyboard).  This  command  generates 
a  species  of  spreadsheet  corresponding  to  rows  and  columns  of  a  matrix 
(Details  on  using  the  Matrix  Writer  to  enter  matrices  will  be  presented  in  a 
subsequent  chapter).  For  a  vector  we  are  interested  in  filling  only  elements  in 
the  top  row.  By  default,  the  cell  in  the  top  row  and  first  column  is  selected. 
At  the  bottom  of  the  spreadsheet  you  will  find  the  following  soft  menu  keys: 


The  EMI  key  is  used  to  edit  the  contents  of  a  selected  cell  in  the 
Matrix  Writer. 

The  EliSS  key,  when  selected,  will  produce  a  vector,  as  opposite  to  a 
matrix  of  one  row  and  many  columns. 
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Vectors  vs.  matrices 

To  see  the  Bllii  key  in  action,  try  the  following  exercises: 

(1)  Launch  the  Matrix  Writer  ((JnDwzl?!^  ).  With  IIIIjiCilB  and  EiiU"  selected, 
enter  CTD(^C1H(^CX)(^(^.  This  produces  [3.  5.  2.].  (In  RPN 
mode,  you  can  use  the  following  keystroke  sequence  to  produce  the 
same  result:  CTlC^CTlC^rTllMHjpj^ 

(2)  With  deselected  and  Ba^.B  selected,,  enter 
CX)C^CTDC^CTD(^(^.  This  produces  [[3.  5.  2.]]. 

Although  these  two  results  differ  only  in  the  number  of  brackets  used,  for  the 
calculator  they  represent  different  mathematical  objects.  The  first  one  is  a 
vector  with  three  elements,  and  the  second  one  a  matrix  with  one  row  and 
three  columns.  There  are  differences  in  the  way  that  mathematical  operations 
take  place  on  a  vector  as  opposite  to  a  matrix.  Therefore,  for  the  time  being, 
keep  the  soft  menu  key  EImb  selected  while  using  the  Matrix  Writer. 


The  <-Jiiij!i  key  is  used  to  decrease  the  width  of  the  columns  in  the 
spreadsheet.  Press  this  key  a  couple  of  times  to  see  the  column  width 
decrease  in  your  Matrix  Writer. 

The  IIIij3->  key  is  used  to  increase  the  width  of  the  columns  in  the 
spreadsheet.  Press  this  key  a  couple  of  times  to  see  the  column  width 
increase  in  your  Matrix  Writer. 

The  SiE^H  key,  when  selected,  automatically  selects  the  next  cell  to 
the  right  of  the  current  cell  when  you  press  {enter).  This  option  is 
selected  by  default. 

The  EEi  key,  when  selected,  automatically  selects  the  next  cell  below 
the  current  cell  when  you  press  [enter]  . 


Moving  to  the  right  vs.  moving  down  in  the  Matrix  Writer 

Activate  the  Matrix  Writer  and  enter  CX] [enter] [~5~] [emter) f"2~) Iemter) (enter)  with  the 
key  selected  (default).  Next,  enter  the  same  sequence  of  numbers  with 
the  IHElia  key  selected  to  see  the  difference.  In  the  first  case  you  entered  a 
vector  of  three  elements.  In  the  second  case  you  entered  a  matrix  of  three 
rows  and  one  column. 
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Activate  the  Matrix  Writer  again  by  using  I  <i  jyraiv  ^  and  press  [nxt]  to  check 
out  the  second  soft  key  menu  at  the  bottom  of  the  display.  It  will  show  the 
keys: 

avwxm  Bn-nnn  anan-an  ar.vMTa5  »    'ix-un-a!!!  !!~!>:>!r:!>:>Ea 

uauj  rnmiA  luia^ji  ujui^i  iuuuub 

The  EUISCI  key  will  add  a  row  full  of  zeros  at  the  location  of  the 

selected  cell  of  the  spreadsheet. 

The  gILiiillj  key  will  delete  the  row  corresponding  to  the  selected  cell  of 
the  spreadsheet. 

The  key  will  add  a  column  full  of  zeros  at  the  location  of  the 

selected  cell  of  the  spreadsheet. 

The  key  will  delete  the  column  corresponding  to  the  selected 

cell  of  the  spreadsheet. 

The  ->''«j'L"ii  key  will  place  the  contents  of  the  selected  cell  on  the  stack. 
The  key,  when  pressed,  will  request  that  the  user  indicate  the 

number  of  the  row  and  column  where  he  or  she  wants  to  position  the 
cursor. 

Pressing  [nxt]  once  more  produces  the  last  menu,  which  contains  only  one 
function  iijiiijs  (delete). 

The  function  MMm.  will  delete  the  contents  of  the  selected  cell  and 
replace  it  with  a  zero. 

To  see  these  keys  in  action  try  the  following  exercise: 

(1)  Activate  the  Matrix  Writer  by  using  (^J/wnw  .   Make  sure  the  Eliua  and 
ES^B  keys  are  selected. 

(2)  Enter  the  following: 

CT]  (wra]       (oth]  [m^ 
[nxtJ  iiiiliijijill  l_2_J IIIEIuillli  [__/_J  i !. !.  ii !  iivJjjiii 

(^^2j       LJJ  (^!™J  LjLJ 'i?™^ 

C7~]lENTER}C8~]llNTER}l  9  J[fAffiE<iJ 

(3)  Move  the  cursor  up  two  positions  by  using  ("^/^/^ .  Then  press  SGHj. 
The  second  row  will  disappear. 

(4)  Press  IQ^CI.  A  row  of  three  zeroes  appears  in  the  second  row. 
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(5)  Press  BIM.  The  first  column  will  disappear. 

(6)  Press  Ibl^ul!:!.  A  row  of  two  zeroes  appears  in  tfie  first  row. 

(7)  Press         [TDIEai  CTDIEEi  !uI!3S  to  move  to  position  (3,3). 

(8)  Press  This  will  place  the  contents  of  cell  (3,3)  on  the  stack, 
although  you  will  not  be  able  to  see  it  yet. 

(9)  Press  [waj  to  return  to  normal  display.   Element  (3,3)  and  the  full  matrix 
will  be  available  in  the  screen. 


Summary  of  Matrix  Writer  use  for  entering  vectors 

In  summary,  to  enter  a  vector  using  the  Matrix  Writer,  simply  activate  the 
writer  ([  <n  jumv  )^  and  place  the  elements  of  the  vector,  pressing  Ifw^^J  after 
each  of  them.  Then,  press  (mM}(^R}.  Make  sure  that  the  ElilflB  and  S3u^»l 
keys  are  selected. 

Example:  C^um  Q3(^(3](gC?3CZD(^CX)(^CIDC^ 
produces:  ['x'^2'  2  -5  ] 


Building  a  vector  with  ^ARRY 

The  function  ^ARRY,  available  in  the  function  catalog  (I j^^l  cat^  I j^l  — ^ , 
use  (^'^^  to  locate  the  function),  can  also  be  used  to  build  a  vector  or 
array  in  the  following  way.  In  ALG  mode,  enter  ^ARRY(vector  elements, 
number  of  elements),  e.g^  


:-*flRRY(  1,2,3,4,45 

[1  2 

3  4] 

:-*flRRY(  1,-2,-3,3) 

[1  -2 

-3] 

:-*flRRY(o:,p,i,3) 

 [a 

+^KIP|SKIP^  H)EL  1  DEL-f 

DEL  L| 

ins  ■ 

In  RPN  mode: 

(1)  Enter  the  n  elements  of  the  array  in  the  order  you  want  them  to  appear  in 
the  array  (when  read  from  left  to  right)  into  the  RPN  stack. 

(2)  Enter  n  as  the  last  entry. 

(3)  Use  function  ^ARRY. 
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The  following  screen  shots  show  the  RPN  stack  before  and  after  applying 
function  ^ARRY: 


6: 
5: 
4: 
3: 
Z: 
l: 


-5 
-4 
-3 
-2 
1 
5 


3: 
5: 
4: 
3: 
Z: 
l: 


[-5  -4  -3-2  1] 


In  RPN  mode,  the  function  [^ARRY]  takes  the  objects  from  stack  levels  n+1,  n, 
n-1,  down  to  stack  levels  3  and  2,  and  converts  them  into  a  vector  of  n 
elements.  The  object  originally  at  stack  level  n+1  becomes  the  first  element, 
the  object  originally  at  level  n  becomes  the  second  element,  and  so  on. 


Note:  Function  ^ARRY  is  also  available  in  the  PRG/TYPE  menu  (CSD^  ) 


Identifying,  extracting,  and  inserting  vector  elements 

If  you  store  a  vector  into  a  variable  name,  say  A,  you  con  identify  elements  of 
the  vector  by  using  A(i),  where  i  is  an  integer  number  less  than  or  equal  to  the 
vector  size.  For  example,  create  the  following  array  and  store  it  in  variable 
A:  [-1 ,  -2,  -3,  -4,  -5]:   


[-1  -2  -3  -4  -51¥f\ 

[-1  -2  -3  -4  -5] 


To  recall  the  third  element  of  A,  for  example,  you  could  type  in  A(3)  into  the 
calculator.    In  ALG  mode,  simply  type  A(3).    In  RPN  mode,  type  'A(3)' 


ENTg<][EVAL 


You  can  operate  with  elements  of  the  array  by  writing  and  evaluating 
algebraic  expressions  such  as: 


R(2)+R(5) 
R(l)-R(4) 
R(3)fl(2) 


-7 

3 


Rt3) 
flt5) 

LH(R(5)) 


3 
5 

LHt5)+id 
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R(3) 


2.J5 


More  complicated  expressions  involving  elements  of  A  can  also  be  written. 
For  example,  using  the  Equation  Writer  ([  J  cow ),  we  can  write  the  following 
summation  of  the  elements  of  A: 


Highlighting  the  entire  expression  and  using  the  BIHS  soft  menu  key,  we  get 

the  result:  ■ 


Note:  The  vector  A  can  also  be  referred  to  as  an  indexed  variable  because 
the  name  A  represents  not  one,  but  many  values  identified  by  a  sub-index. 
To  replace  an  element  in  an  array  use  function  PUT  (you  can  find  it  in  the 
function  catalog  (TfJ^Qv  ,  or  in  the  PRG/LIST/ELEMENTS  sub-menu  -  the  later 
was  introduced  in  Chapter  8).  In  ALG  mode,  you  need  to  use  function  PUT 
with  the  following  arguments:  PUT(array,  location  to  be  replaced,  new  value). 
For  example,  to  change  the  contents  of  A{3)  to  4.5,  use: 


PUT(R,3,4.5) 

[-1  -2  4.5-4  -51 


In  RPN  mode,  you  can  change  the  value  of  an  element  of  A,  by  storing  a  new 
value  in  that  particular  element.  For  example,  if  we  want  to  change  the 
contents  of  A(3)  to  read  4.5  instead  of  its  current  value  of  -3.,  use: 

To  verify  that  the  change  took  place  use:  I  r»  jlKIB  .  The  result  now  shown  is: 
[-1  -2  4.5  -4  -5  ]. 
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Note:  This  approach  for  changing  the  value  of  an  array  element  is  not 
allowed  in  ALG  mode,  if  you  try  to  store  4.5  into  A(3)  in  this  mode  you  get 
the  following  error  message:  Invalid  Syntax. 


To  find  the  length  of  a  vector  you  can  use  the  function  SIZE,  available  through 
the  command  catalog  (N)  or  through  the  PRG/LIST/ELEMENTS  sub-menu. 
Some  examples,  based  on  the  arrays  or  vectors  stored  previously,  are  shown 
below: 


SIZE(y3) 
SIZE(u2) 
SIZE(R) 


{3.} 
{2.} 
{5.} 


Simple  operations  with  vectors 

To  illustrate  operations  with  vectors  we  will  use  the  vectors  A,  u2,  u3,  v2,  and 
v3,  stored  in  an  earlier  exercise. 

Changing  sign 

To  change  the  sign  of  a  vector  use  the  key  I  +/-  J,  e.g., 


:  -L2  3  5] 

:-y3 

:-fl 


[-2  -3  -5] 
[-1  5  -2] 
[1  2  3  4  5] 


Addition,  subtraction 

Addition  and  subtraction  of  vectors  require  that  the  two  vector  operands  have 
the  same  length: 


u2+y2 
u3+y3 
R+R 


[4  1] 
[-2  -3  0] 
[-2  -4  -6  -3  -10] 
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Attempting  to  add  or  subtract  vectors  of  different  lengtfi  produces  an  error 
message  (Invalid  Dimension),  e.g.,  v2+v3,  u2+u3,  A+v3,  etc. 

Multiplication  by  a  scalar,  and  division  by  a  scalar 

Multiplication  by  a  scalar  or  division  by  a  scalar  is  straightforward: 


-5.u3 


[9  -3] 
[15  -10  10] 
[-16  10] 


u3 
2 


Absolute  value  function 

The  absolute  value  function  (ABS),  when  applied  to  a  vector,  produces  the 
magnitude  of  the  vector.  For  o  vector  A  =  [Ai,A2,...,A„],  the  magnitude  is 

defined  as  \  A\=  J      +  A[,  ^  ^      .  In  the  ALG  mode,  enter  the  function 


name  followed  by  the  vector  argument.  For  example:  RBS^  L  1  ? 
flBSt!Fl>,  RBSi'u3!J,  will  show  in  the  screen  as  follows: 


|[1  -2  6]l 

IRI 

Iu3l 


J4T 
■J55 


The  MTH/VEaOR  menu 

The  MTH  menu  (L  <n  ]mth  )  contains  a  menu  of  functions  that  specifically  to 
vector  objects: 


HHTH  HEnU 

1.  VECTOR..  1 

2.  HATRIK.. 

3.  LIST.. 
H.HYPEREOLIC. 
5.  REAL.. 
e.EASE.. 

1    1  1 

ICAnCL 

OK 

The  VECTOR  menu  contains  the  following  functions  (system  flag  1  1 7  set  to 
CHOOSE  boxes): 
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VECTOR  HERU 

l.RES  1 

2.  DOT 

3. CROSS 

e.-tV3  1 

1       1       1  IcflncL 

OK 

VECTOR  HERU 

5.-tV2  1 
S.-tV3 

S.CVLIR  K 

S^FJHER^^^^^^^^ 

ICHRCL 

OK 

Magnitude 

The  magnitude  of  a  vector,  as  discussed  earlier,  can  be  found  with  function 
ABS.  This  function  is  also  available  from  the  keyboard  ([,  <n  J ^bs   ).  Examples 
of  application  of  function  ABS  were  shown  above. 


Dot  product 

Function  DOT  is  used  to  calculate  the  dot  product  of  two  vectors  of  the  same 
length.  Some  examples  of  application  of  function  DOT,  using  the  vectors  A, 
u2,  u3,  v2,  and  v3,  stored  earlier,  are  shown  next  in  ALG  mode.  Attempts  to 
calculate  the  dot  product  of  two  vectors  of  different  length  produce  an  error 
message]  


DOT(R,R) 

D0T(u2,y2) 

D0T(y3,u3) 


55 
1 

-17 


D0T(u2,u3) 

"Inyalicd  Dimension" 
D0T(R,y3) 

"Inyalicd  Dimension" 
D0T(y2,u3) 

"Inyalicd  Dimension" 


Cross  product 

Function  CROSS  is  used  to  calculate  the  cross  product  of  two  2-D  vectors,  of 
two  3-D  vectors,  or  of  one  2-D  and  one  3-D  vector.  For  the  purpose  of 
calculating  a  cross  product,  a  2-D  vector  of  the  form  [A„  Ay],  is  treated  as  the 
3-D  vector  [A„  Ay,0].  Examples  in  ALG  mode  are  shown  next  for  two  2-D  and 
two  3-D  vectors.  Notice  that  the  cross  product  of  two  2-D  vectors  will  produce 
a  vector  in  the  z-direction  only,  i.e.,  a  vector  of  the  form  [0,  0,  CJ: 


CR0SS(u2,y2) 

[0  0  -73 

CR0SS(u2,[2  -3]) 

[0  0  -73 
CR0SS([1.5  -2],y2) 

[0  0  4.53 


CR0SS(u3,y3) 

L-6  4  133 

CR0SS(u3,u3) 

[0  0  03 
CROSSCl  3  -5],[1  2  3]) 

[19  -3  -13 
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Examples  of  cross  products  of  one  3-D  vector  with  one  2-D  vector,  or  vice 
verso,  ore  presented  next^  


CR0SS(u3,y2) 
CR0SS(y2,y3) 


[-2  -6  -3] 


[-2  -6-143 
CROSSCl  2  3],[5  -6]) 

[13  15  -161 


Attempts  to  calculate  a  cross  product  of  vectors  of  length  other  than  2  or  3, 
produce  an  error  message  (Invalid  Dimension),  e.g.,  CROSS(v3,A),  etc. 


Decomposing  a  vector 

Function  is  used  to  decompose  a  vector  into  its  elements  or  components. 
If  used  in  the  ALG  mode,  will  provide  the  elements  of  the  vector  in  a  list, 
e.g., 


{-1.  -2.  -3.  -4.  -5.}i 

V+(y3) 

a.  -5.  2.}] 

V+(u2) 

a.  2.}] 


In  the  RPN  mode,  application  of  function       will  list  the  components  of  a 
vector  in  the  stock,  e.g.,  V^(A)  will  produce  the  following  output  in  the  RPN 
stack  (vector  A  is  listed  in  stock  level  6:). 


6: 
5: 
4: 
3: 
2: 
l: 


[-1  -2  -3  -4  -5] 
-1 
-2 
-3 
-4 
-5 


Building  a  two-dimensional  vector 

Function  ^V2  is  used  in  the  RPN  mode  to  build  a  vector  with  the  values  in 
stack  levels  1 :  and  2:.  The  following  screen  shots  show  the  stack  before  and 
after  applying  function  ->V2: 


l:  -6 

1:  —I.  —II  —II J-M 
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Building  a  three-dimensional  vector 

Function  ^V3  is  used  in  the  RPN  mode  to  build  a  vector  with  the  values  in 
stack  levels  1 :  ,  2:,  and  3:.  The  following  screen  shots  show  the  stack  before 
and  after  applying  function  ^V2: 


4: 
3: 
2: 
l: 


8 
€ 
2 


4: 
3: 

l: 


[S.  6.  £.] 


Changing  coordinate  system 

Functions  RECT,  CYLIN,  and  SPHERE  are  used  to  change  the  current 
coordinate  system  to  rectangular  (Cartesian),  cylindrical  (polar),  or  spherical 
coordinates.  The  current  system  is  shown  highlighted  in  the  corresponding 
CHOOSE  box  (system  flag  1  1 7  unset),  or  selected  in  the  corresponding 
SOFT  menu  label  (system  flag  1  17  set).  In  the  following  figure  the 
RECTangular  coordinate  system  is  shown  as  selected  in  these  two  formats: 


When  the  rectangular,  or  Cartesian,  coordinate  system  is  selected,  the  top 
line  of  the  display  will  show  an  XYZ  field,  and  any  2-D  or  3-D  vector  entered 
in  the  calculator  is  reproduced  as  the  (x,y,z)  components  of  the  vector.  Thus, 
to  enter  the  vector  A  =  3i+2j-5k,  we  use  [3,2,-5],  and  the  vector  is  shown  as: 

If]  [3  2  -5] 


RECTI  CYLin^FHER 


If  instead  of  entering  Cartesian  components  of  a  vector  we  enter  cylindrical 
(polar)  components,  we  need  to  provide  the  magnitude,  r,  of  the  projection  of 

the  vector  on  the  x-y  plane,  an  angle  6  (in  the  current  angular  measure) 
representing  the  inclination  of  r  with  respect  to  the  positive  x-axis  ,  and  a  z- 
component  of  the  vector.  The  angle  9  must  be  entered  preceded  by  the  angle 
character  (Z),  generated  by  using  ld™]LrlJL6j  ■  For  example,  suppose  that 
we  have  a  vector  with  r  =  5,  9  =  25°  (DEG  should  be  selected  as  the  angular 
measure),  and  z  =  2.3,  we  can  enter  this  vector  in  the  following  way: 
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Before  pressing  [inter]  ,  the  screen  will  look  as  in  the  left-hand  side  of  the 
following  figure.  After  pressing  (ms),  the  screen  will  look  as  in  the  right-hand 
side  of  the  figure  (For  this  example,  the  numerical  format  was  changed  to  Fix, 
with  three  decimals).    


[ 5 ,  ^25,2.3]  

^:      [4.532  2.  113  2.  3SS] 

RECTi|CYLin|£FHER|         |         |  HTH 

HRECTi|CVLin|£PHER|         |         |  HTH 

Notice  that  the  vector  is  displayed  in  Cartesian  coordinates  ,  with  components 
X  =  r  cos(9),  y  =  r  sin(9),  z  =  z,  even  though  we  entered  it  in  polar  coordinates. 
This  is  because  the  vector  display  will  default  to  the  current  coordinate  system. 
For  this  case,  we  have  x  =  4.532,  y  =  2.1 1  2,  and  z  =  2.300. 

Suppose  that  we  now  enter  a  vector  in  spherical  coordinates  (i.e.,  in  the  form 
(p,9,(|)),  where  p  is  the  length  of  the  vector,  6  is  the  angle  that  the  xy  projection 
of  the  vector  forms  with  the  positive  side  of  the  x-axis,  and  (j)  is  the  angle  that  p 

forms  with  the  positive  side  of  the  z  axis),  with  p  =  5,  9  =  25°,  and  (j)  =  45°. 
We  will  useCT(^CID  CB  ;  (d^^CBCU  CTJCE   ! 


The  figure  below  shows  the  transformation  of  the  vector  from  spherical  to 
Cartesian  coordinates,  with  x  =  p  sin((|))  cos(9),  y  =  p  sin  [^)  cos  (9),  z  =  p 
cos((|)).  For  this  case,  x  =  3.204,  y  =1 .494,  and  z  =  3.536.  


[ 5 ,  ^25,^454  

|l:      [3.  2S4  1.494  3.536] 

RECTi|CYLin|£FHER|         |         |  HTH 

^■RECTi|CYLin|£FHER|         |         |  HTH 

If  the  CYLINdrical  system  is  selected,  the  top  line  of  the  display  will  show  an 
RZZ  field,  and  a  vector  entered  in  cylindrical  coordinates  will  be  shown  in  its 
cylindrical  (or  polar)  coordinate  form  (r,9,z).   To  see  this  in  action,  change 
the  coordinate  system  to  CYLINdrical  and  watch  how  the  vector  displayed  in 
the  last  screen  changes  to  its  cylindrical  (polar)  coordinate  form.  The  second 
component  is  shown  with  the  angle  character  in  front  to  emphasize  its  angular 
nature. 


[3.536  ^25.000  3.536^ 


RECT  CYLIi^FHER 
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The  conversion  from  Cartesian  to  cylindrical  coordinates  is  such  that  r  = 
(x^+y^)^''^,  0  =  tan'^(y/x),  and  z  =  z.  For  the  case  shown  above  the 
transformation  was  such  that  (x,y,z)  =  (3.204,  2.1 1  2,  2.300),  produced 
(r,e,z)  =  (3.536,25°,3.536). 


At  this  point,  change  the  angular  measure  to  Radians.  If  we  now  enter  a 
vector  of  integers  in  Cartesian  form,  even  if  the  CYLINdrical  coordinate  system 
is  active,  it  will  be  shown  in  Cartesian  coordinates,  e.g.. 


This  is  because  the  integer  numbers  are  intended  for  use  with  the  CAS  and, 
therefore,  the  components  of  this  vector  are  kept  in  Cartesian  form.  To  force 
the  conversion  to  polar  coordinates  enter  the  vector  components  as  real 
numbers  (i.e.,  add  a  decimal  point),  e.g.,  [2.,  3.,  5.]. 

If]    [3.606  ^0.933  5.000] 


With  the  cylindrical  coordinate  system  selected,  if  we  enter  a  vector  in 
spherical  coordinates  it  will  be  automatically  transformed  to  its  cylindrical 
(polar)  equivalent  (r,9,z)  with  r  =  p  sin  (j),  0  =  6,  z  =  p  cos  (j).  For  example,  the 
following  figure  shows  the  vector  entered  in  spherical  coordinates,  and 
transformed  to  polar  coordinates.  For  this  case,  p  =  5,  0  =  25°,  and  (j)  =  45°, 
while  the  transformation  shows  that  r  =  3.563,  and  z  =  3.536.  (Change  to 
DEG): 


2:  [3.536  ^25.000  3.536* 
1 :  [2  3  5] 
[5,i25,i454 

4: 

3:  [3.536  ^25.000  3.536* 

[2  3  5] 

l:  [3.536  i25.000  3.536* 

RECT  |CYLIi|£FHER|         |         |  HTH 

RECT  |CYLIi|£FHER|         |         |  HTH 

Next,  let's  change  the  coordinate  system  to  spherical  coordinates  by  using 
function  SPHERE  from  the  VECTOR  sub-menu  in  the  MTH  menu.  When  this 
coordinate  system  is  selected,  the  display  will  show  the  RZZ  format  in  the  top 


line.  The  last  screen  wil 


change  to  show  the  following: 


4: 
3: 
2: 
l: 


[5.000  ^25.000  ^45.0* 
[2  3  5] 

[5.000  i25.000  ^45.0* 


RECT  CVLin  SF-HE" 
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Notice  that  the  vectors  that  were  written  in  cylindrical  polar  coordinates  have 
now  been  changed  to  the  spherical  coordinate  system.  The  transformation  is 
such  that  p  =  [r^+z^y^^,  9  =  9,  and  ^  =  tan  '(r/z).  However,  the  vector  that 
originally  was  set  to  Cartesian  coordinates  remains  in  that  form. 

Application  of  vector  operations 

This  section  contains  some  examples  of  vector  operations  that  you  may 
encounter  in  Physics  or  Mechanics  applications. 

Resultant  of  forces 

Suppose  that  a  particle  is  subject  to  the  following  forces  (in  N):  F,  =  3i+5i+2k, 
F2  =  -2i+3j-5k,  and  F3  =  2i-3k.  To  determine  the  resultant,  i.e.,  the  sum,  of  all 
these  forces,  you  can  use  the  following  approach  in  ALG  mode: 


[3  5  2]+[-2  3  -5]+[2  0  -3> 
[3  S  -6] 


Thus,  the  resultant  is  R  =  Fi+  Fj  +  F3  =  (3i+8j-6k)N.    RPN  mode  use: 

C  3  ;i  5  ;i  2.  ]  [INTER]  [ -2.  ;i  3  ;i  "15  J  [ENTER]  [  2.  ;i  S  h  3  ]  [ENTER]  [  +  J  [  +  J 

Angle  between  vectors 

The  angle  between  two  vectors  A,  B,  can  be  found  as  9  =cos"^(A»B/ 1  A|  |  B  j) 
Suppose  that  you  want  to  find  the  angle  between  vectors  A  =  3i-5j+6k,  B  = 
2i+j-3k,  you  could  try  the  following  operation  (angular  measure  set  to  degrees) 
in  ALG  mode: 

1  -  Enter  vectors  [3,-5,6],  press  (^),  [2,1,-3],  press 

2  -  DOT(ANS(l),ANS(2))  calculates  the  dot  product 

3  -  ABS(ANS(3))*ABS((ANS(2))  calculates  product  of  magnitudes 

4  -  ANS(2)/ANS(1 )  calculates  cos(9) 

5  -  ACOS(ANS(l)),  followed  by  ,^NUM(ANS(1)),  calculates  9 
The  steps  are  shown  in  the  following  screens  (ALG  mode,  of  course): 


[3  -5  61 
Z2  1  -3] 

D0T(RHS(1),RHS(2)) 


[3  -5  61 
Z2  1  -3] 
-17 


[2  1  -3] 

DOT(RHS(l),RHS(25) 
IRHS(3)hlRHS(2)l 


-3  bJ 
[2  1  -3] 
-17 
■J70-JT4 
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:  IFlHS(3)MFlHS(£)l 

■J70-JT4 

.  RHS(2) 

■  RHS(l) 

-17 

■J70-JT4 

■J70-JT4 

:RC0S(RHS(1)) 

RCOS 

-17  1 

■J70-JT4J 

:-*HUM(RHS(l)) 

122.391 

Thus,  the  result  is  0  =  1  22.891°.     In  RPN  mode  use  the  following: 

L  3  J  -5  J  b  J  (fWTHl  [  2  J  1 J  ■ 

r  ~i       cr    y  i   r^^T;^  i-ir-n--  r --i  h 

L  :^  !i  ~_i  1  o  J  [£N7H)  nr::'0  L  t::  J  1  j  ■ 


;  J   [ENTER)  ijij  | 

:]        FlBS  CXD 


Moment  of  o  force 

The  moment  exerted  by  a  force  F  about  a  point  O  is  defined  as  the  cross- 
product  M  =  rxF,  where  r,  also  known  as  the  arm  of  the  force,  is  the  position 
vector  based  at  O  and  pointing  towards  the  point  of  application  of  the  force. 
Suppose  that  a  force  F  =  (2i+5j-6k)  N  has  an  arm  r  =  (3i-5j+4k)m.  To 
determine  the  moment  exerted  by  the  force  with  that  arm,  we  use  function 
CROSS  as  shown  next: 


[3  -5  4] 
[2  5  -6] 


[3  -5  4] 


[2  5  -6J 

CR0S3(RHS(2),RHS(1)) 
 [IS  26  25] 


Thus,  M  =  (1 0i+26j-i-25k)  m-N.  We  know  that  the  magnitude  of  M  is  such 
that  I M I  =  I  r  I  j  F  j  sin(9),  where  9  is  the  angle  between  r  and  F.  We  can  find 
this  angle  as,  9  =  sin"^(  |  M  j  /  j  r  j  |  F  | )  by  the  following  operations: 

1  -  ABS(ANS(1))/(ABS(ANS(2))*ABS(ANS(3))  calculates  sin(9) 

2  -  ASIN(ANS(1)),  followed  by  ^NUM(ANS(1))  calculates  9 
These  operations  are  shown,  in  ALG  mode,  in  the  following  screens: 


CR0SS(RHS(2),RHS(1)) 

[10  26  £53 

IRHStDI 


IRHS(2)|.|flHS(3)l 


DOT   CROSS  Oh 


■J65.5-J2 


RSIHtRHSd)) 

RSIH 
■^HUMtRHStD) 


■J65.5-J2 
JT4Sr  ' 


DOT   CROSS  Vi 


.■J65'5-J2 
41.038 
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Thus  the  angle  between  vectors  r  and  F  is  9  =  41 .038°.    RPN  mode,  we  can 
use:  L  3  -5  q  4  J  [mh)  LZiDi  S  j  [inter]    CROSS     flBS  l  3  n  --d  4 11  [enter] 
FIBS  12,5,-61        RBS  CED  S  FiSIN  ^NUM 

Equation  of  a  plane  in  space 

Given  a  point  in  space  Polxo/Yo/^o)       a  vector  N  =  N^i+Nyj+N^k  normal  to  a 
plane  containing  point  Pq,  the  problem  is  to  find  the  equation  of  the  plane. 
We  can  form  a  vector  starting  at  point  Pq  and  ending  at  point  P(x,y,z),  a 
generic  point  in  the  plane.  Thus,  this  vector  r  =  PqP  =  (x-xo)i+  (y-yo)i  +  (^-^o)K 
is  perpendicular  to  the  normal  vector  N,  since  r  is  contained  entirely  in  the 
plane.  We  learned  that  for  two  normal  vectors  N  and  r,  N»r  =0.  Thus,  we 
can  use  this  result  to  determine  the  equation  of  the  plane. 

To  illustrate  the  use  of  this  approach,  consider  the  point  Po(2,3,-l)  and  the 
normal  vector  N  =  4i+6j+2k,  we  can  enter  vector  N  and  point  Pq  as  two 
vectors,  as  shown  below.  We  also  enter  the  vector  [x,y,z]  last: 


:  [4  6  2] 

[4  6  2] 

:[2  3  -1] 

[2  3  -1] 

:  [x  y  z] 

[x  y  z] 

Next,  we  calculate  vector  PpP  =  r  as  ANS(1 )  -  ANS(2),  i.e.. 


[4  &  2] 

:[£  3  -1] 

[2  3  -1] 

:  [x  y  z] 

[x  y  z] 

:RHS(1)-RHS(2) 

[x-2  y 

-3  z— 1] 

Finally,  we  take  the  dot  product  of  ANS(1 )  and  ANS(4)  and  make  it  equal  to 

zero  to  complete  the  operation  N»r  =0: 

I  [2  3  -11 

:  [x  y  z] 

[x  y  z] 

:flHS(l)-flHS(2) 

[x-2  y-3  z~l] 
:DOT(RHS(1),RHS(4))=0 
(z~l).2+(y-3).6+(x-2)4=0 
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We  can  now  use  function  EXPAND  (in  the  ALG  menu)  to  expand  this 
expression: 


RHS(1)-RHS(2) 


[x  y  z] 


[x-2  y-3  z— 13 
DOT(RHS(1),RHS™=0 
(z~  1  >2+(y-3>6+(x-2)4=0| 
EXPRHDtRtTSd)) 

4'X+6'y+2'Z-24=0 


COLLE  EKPfln  FflCTO  LnCOL   Lin  PflRTF 


Thus,  the  equation  of  the  plane  through  point  Po(2,3,-l )  and  having  normal 
vector  N  =  4i+6j+2k,  is  4x  +  6y  +  2z  -  24  =  0.  In  RPN  mode,  use: 


J  i|  -  i  J   [INTER]  i. 


J   [ENTER]  [  —  ]   il  4  J  &  J  2  J  DOT 


Row  vectors,  column  vectors,  and  lists 

The  vectors  presented  in  this  chapter  are  all  row  vectors.  In  some  instances,  it 
is  necessary  to  create  a  column  vector  (e.g.,  to  use  the  pre-defined  statistical 
functions  in  the  calculator).  The  simplest  way  to  enter  a  column  vector  is  by 
enclosing  each  vector  element  within  brackets,  all  contained  within  an 
external  set  of  brackets.  For  example,  enter: 


This  is  represented  as  the  following  column  vector: 


HEHD  THIL 


In  this  section  we  will  showing  you  ways  to  transform:  a  column  vector  into  a 
row  vector,  a  row  vector  into  a  column  vector,  a  list  into  a  vector,  and  a 
vector  (or  matrix)  into  a  list. 


We  first  demonstrate  these  transformations  using  the  RPN  mode.  In  this  mode, 
we  will  use  functions  OBJ^,  ^LIST,  ^ARRY  and  DROP  to  perform  the 
transformation.  To  facilitate  accessing  these  functions  we  will  set  system  flag 
1  1 7  to  SOFT  menus  (see  Chapter  1 ).  With  this  flag  set,  functions  OBJ^, 
^ARRY,  and  ^LIST  will  be  accessible  by  using  CHD™^  SEEi.  Functions 
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OBJ^,  ^ARRY,  and  ^LIST  will  be  available  in  soft  menu  keys  CD  ,  (jT) , 
and  CD  ■  Function  DROP  is  available  by  using  L  <n  Jf^g   l^i^MI  yjii^Iiy. 

Following  we  introduce  the  operation  of  functions  OBJ^,  ^LIST,  ^ARRY,  and 
DROP  with  some  examples. 

Function  OBJ^ 

This  function  decomposes  an  object  into  its  components.  If  the  argument  is  a 
list,  function  OBJ^  will  list  the  list  elements  in  the  stack,  with  the  number  of 
elements  in  stack  level  1,  for  example:  {  1 ,  £,  3>  I^jer)  (^p^  uiGiOi  S333^! 
results  in: 


4: 

1 

3: 

2 

2: 

3 

l: 

3. 

OEJ-f|-tflRRV|-H.IST|  -tSTR 

-HflG  l-HiniT 

when  function  OBJ^  is  applied  to  a  vector,  it  will  list  the  elements  of  the 
vector  in  the  stack,  with  the  number  of  elements  in  level  1 :  enclosed  in  braces 
(a  list).  The  following  example  illustrates  this  application:  L  1  ?  2?  3  J  [inter] 
(33fflG_SilH3  lEEEl^!  results  in:  


4: 

1 

3: 

2 

2: 

3 

l: 

{3.} 

OEJ-f|-tflRRV|-H.IST|  -tSTR 

-HflG  l-HiniT 

If  we  now  apply  function  OBJ^  once  more,  the  list  in  stack  level  1 :,  {3.},  will 
be  decomposed  as  follows]  


7: 

6: 

5: 

1 

4: 

2 

3: 

3 

2: 

3. 

l: 

1. 

ORJ-f|-tflRRV|-H.IST|  -tSTR 

-HflG  l-HiniT 

Function  ^LIST 

This  function  is  used  to  create  a  list  given  the  elements  of  the  list  and  the  list 
length  or  size.  In  RPN  mode,  the  list  size,  say,  n,  should  be  placed  in  stack 
level  1 :.   The  elements  of  the  list  should  be  located  in  stack  levels  2:,  3:, 
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n+1 :.  For  example,  to  create  the  list  {1,  2,  3},  type:  I  /  Renter)  [  2  }[inter} 
CX)(w^  CTD(wra)  C5Dfl?G_lS[jl=i  I^SSl. 

Function  ^ARRY 

This  function  is  used  to  create  a  vector  or  a  matrix.  In  this  section,  we  will  use 
it  to  build  a  vector  or  a  column  vector  (i.e.,  a  matrix  of  n  rows  and  1  column). 
To  build  a  regular  vector  we  enter  the  elements  of  the  vector  in  the  stack,  and 

in  stack  level  1 :  we  enter  the  vector  size  as  a  list,  e.g.,  [  I  Renter]  [  2  }[enter) 
[jjiENTER}  C5Dil_  C5D«?G_  133311  1^333131 

To  build  a  column  vector  of  n  elements,  enter  the  elements  of  the  vector  in  the 
stack,  and  in  stack  level  1  enter  the  list  {n  1}.  For  example,l  /  Renter}  [  2  Renter) 
(jJ{enter}  C3ii_  CTDCED  '[JJiENm)  C5DfflG_liBG@l  I^HIEa. 

Function  DROP 

This  function  has  the  same  effect  as  the  delete  key  ((3D)- 

Transforming  a  row  vector  into  a  column  vector 

We  illustrate  the  transformation  with  vector  [  1  ;i  £  ;i  3  ]  .    Enter  this  vector  into 
the  RPN  stack  to  follow  the  exercise.  To  transform  a  row  vector  into  a  column 
vector,  we  need  to  carry  on  the  following  operations  in  the  RPN  stack: 
1  ■  Decompose  the  vector  with  function  OBJ^ 


4: 

1 

3: 

2 

2: 

3 

l: 

{3.} 

OEJ-f|-tflRRV|-H.IST|  -tSTR 

-HflG  l-HiniT 

2  -  Press  [  /  J[  +  J  to  transform  the  list  in  stack  level  1 :  from  {3}  to  {3,1} 


4: 

1 

3: 

2 

Z: 

3 

l: 

{3.  1} 

OEJ-f|-tflRRV|-H.IST|  -tSTR 

-HflG  l-HiniT 

3  -  Use  function  ^ARRY  to  build  the  column  vector 


l: 

11 

ORJ-f|-tflRRV|-H.IST|  -tSTR 

-HflG  l-HiniT 

These  three  steps  can  be  put  together  into  a  UserRPL  program,  entered  as 
follows  (in  RPN  mode,  still):  [7i]  ffllM  033^11  QJ  GD  1^3333 
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A  new  variable,  iSiiaa,  will  be  available  in  the  soft  menu  labels  after  pressing 


Press  L  r»  jiESIail  to  see  the  program  contained  in  the  variable  RXC: 

This  variable,  KJ^I,  con  now  be  used  to  directly  transform  a  row  vector  to  a 
column  vector.  In  RPN  mode,  enter  the  row  vector,  and  then  press  SEilSSS.  Try, 

for  example:  I"  1  j  2;i  3  J  [entcr)  lilliSB. 

After  having  defined  this  variable  ,  we  can  use  it  in  ALG  mode  to  transform  a 
row  vector  into  a  column  vector.  Thus,  change  your  calculator's  mode  to  ALG 

and  try  the  following  procedure:  [  1  j  £?  3  j  [enter}  [  var  J  SEilSil  L  <n  J  <J       I  <n  J 

^^■s   ,  resulting  in: 


Transforming  a  column  vector  into  a  row  vector 

To  illustrate  this  transformation,  we'll  enter  the  column  vector 

C  [  1  J  J  [  2  ]  J  C  3  ]  ]  in  RPN  mode.  Then,  follow  the  next  exercise  to 

transform  a  row  vector  into  a  column  vector: 

1  -  Use  function  OBJ^  to  decompose  the  column  vector 


4: 

1 

3: 

2 

2: 

3 

l: 

{3.  1.} 

OEJ-f|-tflRRV|-H.IST|  -tSTR 

-HflG  l-HiniT 

2  -  Use  function  OBJ^  to  decompose  the  list  in  stack  level  1 : 


7: 

6: 

1 

5: 

2 

4: 

3 

3: 

3. 

Z: 

1. 

l: 

2. 

OEJ-f|-tflRRV|-H.IST|  -tSTR 

-HflG  l-HiniT 
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3  ■  Press  the  delete  key  L  J  (also  known  as  function  DROP)  to  eliminate  the 
number  in  stack  level  1 : 


5: 

1 

4: 

2 

3: 

3 

Z: 

3. 

l: 

1. 

OEJ-f|-tflRRV|-H.IST|  -tSTR 

-HflG  l-HiniT 

4  -  Use  function  ^LIST  to  create  a  list 


4: 

1 

3: 

2 

2: 

3 

l: 

{3.} 

OEJ-f|-tflRRV|-H.IST|  -tSTR 

-HflG  l-HiniT 

5  -  Use  function  ^ARRY  to  create  the  row  vector 


4: 

3: 

Z: 

l: 

[1  2  3] 

ORJ-f|-tflRRV|-H.IST|  -tSTR 

-HflG  l-HiniT 

These  five  steps  can  be  put  together  into  a  UserRPL  program,  entered  as 
follows  (in  RPN  mode,  still): 

A  new  variable,  IllSlilHI,  will  be  available  in  the  soft  menu  labels  after  pressing 


Press  L  r»  jilmEiil  to  see  the  program  contained  in  the  variable  CXR: 

y  .■•   rir-i  i_v  i~ir"i  i  _v  r\ri^-iri   _vQr"ii-i^.i  \  \ 

w  UDU-7  uo  1.1-7  i.-T.i.jr  -7nr.r.  I  .y  y 


This  variable,  '! I  can  now  be  used  to  directly  transform  a  column  vector  to 
a  row  vector.  In  RPN  mode,  enter  the  column  vector,  and  then  press  iuEIIill. 
Try,  for  example:      L  L  1  J  ?  l2  J  j  l3  J  J  (mh) 

After  having  defined  variable  SSS3S,  we  can  use  it  in  ALG  mode  to  transform  a 
row  vector  into  a  column  vector.  Thus,  change  your  calculator's  mode  to  ALG 
and  try  the  following  procedure: 

L  [  1  ]  ;,  l2j  ,  lBj  ]  {mm}  [mj  iESIiSS  CE)'J—  (3D^M_ 
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resulting  in: 


[12  3] 

Transforming  a  list  into  a  vector 

To  illustrate  this  transformation,  we'll  enter  the  list  i  ?  2?  3>  in  RPN  mode. 
Then,  follow  the  next  exercise  to  transform  a  list  into  a  vector: 

1  -  Use  function  OBJ^  to  decompose  the  column  vector 


4: 

1 

3: 

2 

2: 

3 

l: 

3. 

OEJ-f|-tflRRV|-H.IST|  -tSTR 

-HflG  l-HiniT 

2  -  Type  a  1  and  use  function  ^LIST  to  create  a  list  in  stack  level  1 : 


4: 

1 

3: 

2 

2: 

3 

l: 

{3.} 

OEJ-f|-tflRRV|-H.IST|  -tSTR 

-HflG  l-HiniT 

3  -  Use  function  ^ARRY  to  create  the  vector 

|l:  [12  3^ 


ORJ-f|-tflRRV|-H.IST|  tSTR  |  -HflG  |-HiniT 


These  three  steps  can  be  put  together  into  a  UserRPL  program,  entered  as 
follows  (in  RPN  mode): 

(33^l^fflG_imi:ii  llMl^i  UJ  l^:!OIilll^3iESi! 

l_J_J{MmA}{ALm)(L](X}(V]   [ENT£lf}  [STC»] 

A  new  variable,  I133B,  will  be  available  in  the  soft  menu  labels  after  pressing 

[  w!  J : 

I 

l:  

Press  L  r»  jKatEIS  to  see  the  program  contained  in  the  variable  LXV: 

.■■  .•■    t"'ii~i  IX    H      XI    T  i---r     X  r"ii"ir'i"..'   \  ■■. 

\  \  J.         .Loi   -7nr.ri  i  y  .y 

This  variable,  EEEIB,  can  now  be  used  to  directly  transform  a  list  into  a  vector. 
In  RPN  mode,  enter  the  list,  and  then  press  S3!SSS.  Try,  for  example: 

:■    -J  ( r^,Tm\  HS'lB'irnilB 

■■.  1  ;i      ;i      .■■  [£NT£Rj  mSOjm. 
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After  having  defined  variable  lillLli^lli,  we  can  use  it  in  ALG  mode  to  transform  a 
list  into  a  vector.  Tfius,  cfiange  your  calculator's  mode  to  ALG  and  try  tfie 

following  procedure:  i  1,2,3}        (mj  SESxl!  (33^^      C5D^M_ ,  resulting 

in: 


:LXV(RHS(1)) 

[1  2  3] 

Transforming  a  vector  (or  matrix)  into  a  list 

To  transform  a  vector  into  a  list,  tfie  calculator  provides  function  AXL.  You  can 
find  this  function  through  the  command  catalog,  as  follows: 

As  an  example,  apply  function  AXL  to  the  vector  C  3]  in  RPN  mode  by 
using:!!!  1  n  2;i  3!]  (wh)  flXL.  The  following  screen  shot  shows  the  application 
of  function  AXL  to  the  same  vector  in  ALG  mode. 


:RXL([1  2  3]) 

{1  2  3} 
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Chapter  10 

Creating  and  manipulating  matrices 

This  chapter  shows  a  number  of  examples  aimed  at  creating  matrices  in  the 
calculator  and  demonstrating  manipulation  of  matrix  elements. 

Definitions 

A  matrix  is  simply  a  rectangular  array  of  objects  (e.g.,  numbers,  algebraics) 
having  a  number  of  rows  and  columns.  A  matrix  A  having  n  rows  and  m 
columns  will  hove,  therefore,  nxm  elements.  A  generic  element  of  the  matrix 
is  represented  by  the  indexed  variable  Oij,  corresponding  to  row  i  and  column 
j.  With  this  notation  we  can  write  matrix  A  as  A  =  [aijjnxm  •  The  full  matrix  is 
shown  next: 


A  —  [Cly  ]„x„  — 


a. 


a 


12 


a 


Im 


*21 


a 


22 


a 


a 


nl 


a. 


A  matrix  is  square  if  m  =  n.   The  transpose  of  a  matrix  is  constructed  by 
swapping  rows  for  columns  and  vice  versa.  Thus,  the  transpose  of  matrix  A,  is 
A^  =  [(a^)i|]  n,xn  =  [cijilmxn-  The  main  diagonal  of  a  square  matrix  is  the  collection 
of  elements  Oi,.  An  identity  matrix,       is  a  square  matrix  whose  main 
diagonal  elements  are  all  equal  to  1 ,  and  all  off-diagonal  elements  are  zero. 
For  example,  a  3x3  identity  matrix  is  written  as 

"1    0  0' 


I 


An  identity  matrix  can  be  written  as  I 
as  Kronecker's  delta,  and  defined  as 


0  1  0 
0    0  1 

'nxn  =  [Sij],  where  ?>y  is  a  function  known 
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Entering  matrices  in  the  stack 

In  this  section  we  present  two  different  metfiods  to  enter  matrices  in  the 
calculator  stack:  (1)  using  the  Matrix  Writer,  and  (2)  typing  the  matrix  directly 
into  the  stack. 

Using  the  Matrix  Writer 

As  with  the  case  of  vectors,  discussed  in  Chapter  9,  matrices  can  be  entered 
into  the  stack  by  using  the  Matrix  Writer.  For  example,  to  enter  the  matrix: 


-2.5     4.2  2.0 
0.3      1.9     2.8  , 
2      -0.1  0.5 

first,  start  the  matrix  writer  by  using  \jj^]MTiiw  .  Make  sure  that  the  option 
ll£EI->B  is  selected.  Then  use  the  following  keystrokes: 


At  this  point,  the  Matrix  Writer  screen  may  look  like  this: 


Press  [waj  once  more  to  place  the  matrix  on  the  stack.  The  ALG  mode  stack  is 


[[-2.5,' 
[.3, 1.* 
[2,-.l 

4.2,2] 
3,2.3] 
,  .5]] 

-2.5  4. 
.3  1. 
2  -. 


2  2 
9  2.3 
1  .5 

-2. 


54.2  2 
.3  1.92.31 
2  -.1.5 
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If  you  have  selected  the  textbook  display  option  (using  [Moofjli^jaal  and  checking 
off  :!^^Textbook),  the  matrix  will  look  like  the  one  shown  above.  Otherwise, 
the  display  will  show: 


[[-£.5,4.£,£] 
[.3, 1.9,2.3] 
[2,-. 1, .5]] 

[[-2.5,4.2,2] 
[.3, 1.9,2.3] 
[2,-. 1, .5]] 


The  display  in  RPN  mode  will  look  very  similar  to  these. 


Note:  Details  on  the  use  of  the  matrix  writer  were  presented  in  Chapter  9 


Typing  in  the  matrix  directly  into  the  stack 

The  same  result  as  above  can  be  achieved  by  entering  the  following  directly 
into  the  stack: 

ODGDCIDra  C3  !  ODCZDCZD  C3  >  CZD  CD 

CZD  ! 

GDQD  ED  !  CDCZDdD  C3  !  QDCZDCED  CD 

 ; 

CT)  O  !  CDODS   '  GDGD 

Thus,  to  enter  a  matrix  directly  into  the  stack  open  a  set  of  brackets  (I  *i  J(j  ] 

and  enclose  each  row  of  the  matrix  with  an  additional  set  of  brackets 

(L!lJ(^  )•  Commas  (LhJ  ;  CZ^D)  should  separate  the  elements  of  each 

row,  as  well  as  the  brackets  between  rows.  (Note:  In  RPN  mode,  you  can 
omit  the  inner  brackets  after  the  first  set  has  been  entered,  thus,  instead  of 
typing,  for  example,  [[1  2  3]  [4  5  6]  [7  8  9]],  type  [[1  2  3]  4  5  6  7  8  9].) 

For  future  exercises,  let's  save  this  matrix  under  the  name  A.  In  ALG  mode 
use  Isto*](alfha}{a)  .  In  RPN  mode,  use  CZDl^^Sl  • 


Creating  matrices  with  calculator  functions 

Some  matrices  can  be  created  by  using  the  calculator  functions  available  in 
either  the  MTH/MATRIX/MAKE  sub-menu  within  the  MTH  menu  (CSD^Zw.  ), 
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HATH  HEnU 

1. VECTOR..  1 

a.MflTRIK.. 

3. LIST.. 
H.HVPERROLIC. 
5. REAL.. 
e.EASE.. 

1       1       1  IcfincL 

OH 

HATRIH  HERU 

a.nORHALIZE..  1 

3.  FACTORS.. 

H.COL.. 

5.R0H.. 

1         1  1 

ICARCL 

OH 

or  in  the  MATRICES/CR 


EATE  menu  available  through  i^jMAmas 

HATRICES  HERU 

1.  CREATE..  II 

a.OF-ERATIOnS..  1 
3.FACT0RIZATI0n..  1 
H. QUADRATIC  FORM..  1 
S.LIREAR  SYSTEHS..  H 
e.LIREAR  ARPL..  [| 

1      1      1  IcAnciT 

OH 

The  MTH/MATRIX/MAKE  sub  menu  (let's  call  it  the  MAKE  menu)  contains  the 
following  functions: 


HATRIH  HAHE  HERU 

HATRIH  HAHE  HERU 

?.flET  [ 

S.GETI 

3.TRR 

S.PUT 

H.RDH 

lO.PUTI 

5.RARH 

ll.SUR 

C.SIZE 

1         1         1  ICARCL 

OH 

1         1         1  ICARCL 

OH 

HATRIH  HAHE  HERU 


12.  REPL 

13.  -*IAG 
IH.DIAG-f 
15.VARDERH0RDE 
IC.HILRERT 


1?. HATRIH.. 


while  the  MATRICES/CREATE  sub-menu  (let's  call  it  the  CREATE  menu)  has  the 
following  functions: 


HATRIH  CREATE  HERU 

2.R0H.. 

3.AUCHEnT 

H.IDR 

5.  COR 

5. -HIM 

1         1         1  ICARCL 

OH 

HATRIH  CREATE  HERU 

?.DIAfl-f  II 

S.GET 

3.GETI 

lO.HILRERT 

11. PUT 

12.PUTI  [ 

1         1         1  ICARCL 

OH 
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HHTRIX  CREHTE  HEHU 

l^.RHHH  1 

IH.RDH 

15.RERL 

l^.VHHDERHOnDE 

IS.HATRICEf..  1 

1       1       1  icflncL 

OK 

As  you  can  see  from  exploring  these  menus  (MAKE  and  CREATE),  they  both 
have  the  same  functions  GET,  GETI,  PUT,  PUTI,  SUB,  REPL,  RDM,  RANM, 
HUBERT,  VANDERMONDE,  IDN,  CON,  ^DIAG,  and  DIAG^.  The  CREATE 
menu  includes  the  COLUMN  and  ROW  sub-menus,  that  are  also  available 
under  the  MTH/MATRIX  menu.   The  MAKE  menu  includes  the  functions  SIZE, 
that  the  CREATE  menu  does  not  include.  Basically,  however,  both  menus, 
MAKE  and  CREATE,  provide  the  user  v/ith  the  same  set  of  functions.  In  the 
examples  that  follow,  we  will  show  how  to  access  functions  through  use  of  the 
matrix  MAKE  menu.  At  the  end  of  this  section  we  present  a  table  with  the 
keystrokes  required  to  obtain  the  same  functions  with  the  CREATE  menu  when 
system  flag  1  1 7  is  set  to  SOFT  menus. 

If  you  have  set  that  system  flag  (flag  1 1 7)  to  SOFT  menu,  the  MAKE  menu  will 
be  available  through  the  keystroke  sequence:  L  <n  J Mm_  IIISIj jS  IIIIIIIll 

The  functions  available  will  be  shown  as  soft-menu  key  labels  as  follows  (press 
C^D  to  move  to  the  next  set  of  functions): 


RDH  RHRH^IZE 

GE 

r    GETI  PUl 

RUTI    £UR  RERL 

With  system  flag  1 1  7  set  to  SOFT  menus,  the  functions  of  the  CREATE  menu, 
triggered  by  (jnjAwwgH  jyiCiiiiiiiji  ,will  show  as  follows: 


■BWMIlHIH;HT!m 


con  -4IHG 


GET    GETI  HILRE   RUT  RUTI 


RHRH    RDH    RERL    £UR   VHRDE  HHTRX 


In  the  next  sections  we  present  applications  of  the  matrix  functions  in  the 
MAKE  and  CREATE  menu. 
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Functions  GET  and  PUT 

Functions  GET,  GETI,  PUT,  and  PUTI,  operate  with  matrices  in  a  similar 
manner  as  with  lists  or  vectors,  i.e.,  you  need  to  provide  the  location  of  the 
element  that  you  want  to  GET  or  PUT.  However,  while  in  lists  and  vectors  only 
one  index  is  required  to  identify  an  element,  in  matrices  we  need  a  list  of  two 
indices  {row,  column}  to  identify  matrix  elements.    Examples  of  the  use  of 
GET  and  PUT  follow. 


Let's  use  the  matrix  we  stored  above  into  variable  A  to  demonstrate  the  use  of 
the  GET  and  PUT  functions.  For  example,  to  extract  element  023  from  matrix  A, 
in  ALG  mode,  can  be  performed  as  follows: 


:GET(R,{2  3» 

2.8 

:  R(2,3) 

2.8 

GET  IGETII  PUT  |  PUTI 

£UP  IREPL 

Notice  that  we  achieve  the  same  result  by  simply  typing  FM- !■::!;!  3)  and 
pressing  (entek].  In  RPN  mode,  this  exercise  is  performed  by  entering  EI 

(.  3  J  fjNfa]  GET,  or  by  using  Fv:!?!:?  3'>  {entek]. 

Suppose  that  we  want  to  place  the  value  'k'  into  element  031  of  the  matrix. 


We  can  use  function  PU 


for  that  purpose,  e.g.. 


:PUT(R,{3  1} 

.TT) 

-2.5  4.2   2  1 
.3  1.92.3 

.     TT      -.1  .SJ 

GET  IGETII  PUl 

IPUTII  £UP  IREPL 

In  RPN  mode  you  can  use:  Ij^        ■    •  -i  ■■■        SDJ   PUT. 

Alternatively,  in  RPN  mode  you  can  use:  QDJ  [  ■  }f\''.2)  3>  (^)  [sto]  . 

To  see  the  contents  of  variable  A  after  this  operation,  use  iSTISS. 

Functions  GETI  and  PUTI 

Functions  PUTI  and  GETI  are  used  in  UserRPL  programs  since  they  keep  track 
of  an  index  for  repeated  application  of  the  PUT  and  GET  functions.  The 
index  list  in  matrices  varies  by  columns  first.   To  illustrate  its  use,  we  propose 
the  following  exercise  in  RPN  mode:  B3BS   {2,2}[enter}  GETI.  Screen  shots 
showing  the  RPN  stack  before  and  after  the  application  of  function  GETI  are 
shown  below: 
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t  ■ 

3: 

r-2.5  4.2  2  1 

.3     1.9  TT 

I    2    -.  1  .5J 

2: 

{2.  3.} 

l: 

1.9 

GET  IGETI 

PUT  IPUTII  SUE  IREPL 

Notice  that  the  screen  is  prepared  for  a  subsequent  application  of  GETI  or 
GET,  by  increasing  the  column  index  of  the  original  reference  by  1,  (i.e.,  from 
{2,2}  to  {2,3}),  while  showing  the  extracted  value,  namely  A(2,2)  =  1 .9,  in 
stack  level  1 . 


Now,  suppose  that  you  want  to  insert  the  value  2  in  element  {3  1}  using  PUTI. 
Still  in  RPN  mode,  try  the  following  keystrokes:  (3D  CiD  f  3  1  >  CZJ 
IfwraJ  PUTI .  The  screen  shots  below  show  the  RPN  stack  before  and  after  the 
application  of  function  PUTI: 


t . 

3: 

r-2.5  4. 

2  2  i 

3: 

I  -i  i; 

9   TT  1 

[-2.54.2  21 

1  .51 

.3     1.9   TT  1 

2: 

{3  ij 

I   2    -.  1  .5J 

l: 

l:   

{3.  2.?^ 

GET 

IGETII  PUT  IPUTII  SUP 

1  REPL  H 

GET  IGETI 

PUT  1  PUTI  1  SUE  1  REPL  | 

In  this  case,  the  2  was  replaced  in  position  {3  1},  i.e.,  now  A(3, 1)  =  2,  and 
the  index  list  was  increased  by  1  (by  column  first),  i.e.,  from  {3,1}  to  {3,2}. 
The  matrix  is  in  level  2,  and  the  incremented  index  list  is  in  level  1 . 


Function  SIZE 

Function  SIZE  provides  a  list  showing  the  number  of  rows  and  columns  of  the 
matrix  in  stack  level  1 .  The  following  screen  shows  a  couple  of  applications  of 
function  SIZE  in  ALG  mode: 


SIZE(R) 


{3.  3.) 


  {2.  2 


In  RPN  mode,  these  exercises  are  performed  by  using 
[[1,2]. 


:!,  and 
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Function  TRN 

Function  TRN  is  used  to  produce  the  transconjugote  of  a  matrix,  i.e.,  the 
transpose  (TRAN)  followed  by  its  complex  conjugate  (CONJ).  For  example, 
the  following  screen  shot  shows  the  original  matrix  in  variable  A  and  its 
transpose,  shown  in  small  font  display  (see  Chapter  1): 


r-a.5  H.a  a  i 

:A-i.a.A 

r-a.5~a.5.i.a  H.a-H.a.i.a  a-a.i.a 

.3-.3.i.a     1.3-1.3.i.a   n-n.i.a  • 
L    a-a.i.a     -.i~.i.i.a  .s-.s.i.a 

|-a.5~a.s.i.a  H.a-H.a.i.a  a-a-i.a 
1    .3-.3.i.a     i.s-i.s.i.a   n-n-i.a  1 
1    a-a.i.a     -.i~.i.i.a  .s-.s.i.a. 
kRn(fl-i.a.fl) 

|-a.s~a.s.-i.a  .3-.3.-i.a  a-a.- 

1  H.2-H.2.-i.2    1. 3-1. 3.-i.a  -.!--.> 

1    a-a.-i.a        n-n.-i.a  .s-.s. 

If  the  argument  is  a  real  matrix,  TRN  simply  produces  the  transpose  of  the  real 
matrix.  Try,  for  example,  TRN(A),  and  compare  it  with  TRAN(A). 


In  RPN  mode,  the  transconjugote  of  matrix  A  is  calculated  by  using 


Note:  The  calculator  also  includes  Function  TRAN  in  the 
MATRICES/OPERATIONS  sub-menu: 


MATRICES  MEAU 

1.  CREATE..  1 

a.OF-ERATIOAS.. 

3.FACT0RiaATI0A..  1 
H. QUADRATIC  FORM..  1 
S.LIAEAR  SYSTEMS..  H 
S.LIAEAR  APPL..  || 

1         1         1  ICAnCLl 

OK 

MATRIX  OPERATIOnS  MEAU 

IJ.SiaE 
IH.SARM 
IS.SRAD 
IC. TRACE 

17.TRAA 

If  .MATRICES..  1 

HELPI         1         1  ICAACL 

OK 

For  example,  in  ALG  mode: 


:TRRH(R) 

r-2.5  .3    2  1 

4.2  1.9  -.  1 

I     2        TT  .5] 

Function  CON 

The  function  takes  as  argument  a  list  of  two  elements,  corresponding  to  the 
number  of  row  and  columns  of  the  matrix  to  be  generated,  and  a  constant 
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value.  Function  CON  generates  a  matrix  with  constant  elements.  For 
example,  in  ALG  mode,  the  following  command  creates  a  4x3  matrix  whose 
elements  are  all  equal  to  -1 .5: 


:  C0H({4  3 

i-1.5) 

-1.5-1.5-1.51 
-1.5-1.5-1.5 
-1.5-1.5-1.5 
-1.5  -1.5  -I.5J 

+^KIP|SKIP^ 

H)EL  1  DEL-f|DEL  L|  inS  ■ 

in  RPN  mode  this  is  accomplished  by  using   4?  3>        CjJGJCiJ  GED 
(w^  COH. 

Function  IDN 

Function  IDN  (IDeNtity  matrix)  creates  an  identity  matrix  given  its  size.  Recall 
that  an  identity  matrix  has  to  be  a  square  matrix,  therefore,  only  one  value  is 
required  to  describe  it  completely.  For  example,  to  create  a  4x4  identity 
matrix  in  ALG  mode  use: 


:  IDH(4) 

fl  0  0  01 

0  10  0 

0  0  10 

.0  0  0  iJ 

You  can  also  use  an  existing  square  matrix  as  the  argument  of  function  IDN, 
e.g.,  ^  ^ 


:  IDH(R) 

ri  0  01 

0  1  0 

L0  0  iJ 

The  resulting  identity  matrix  will  have  the  same  dimensions  as  the  argument 
matrix.  Be  aware  that  an  attempt  to  use  a  rectangular  (i.e.,  non-square) 
matrix  as  the  argument  of  IDN  will  produce  an  error. 

In  RPN  mode,  the  two  exercises  shown  above  are  created  by  using:  [  4  ][£nter] 
IDN  andSEim  IDN. 
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Function  RDM 

Function  RDM  (Re-DiMensioning)  is  used  to  re-write  vectors  and  matrices  as 
matrices  and  vectors.  The  input  to  the  function  consists  of  the  original  vector 
or  matrix  followed  by  a  list  of  a  single  number,  if  converting  to  a  vector,  or 
two  numbers,  if  converting  to  a  matrix.  In  the  former  case  the  number 
represents  the  vector's  dimension,  in  the  latter  the  number  of  rows  and 
columns  of  the  matrix.  The  following  examples  illustrate  the  use  of  function 
RDM: 

Re-dimensioning  a  vector  into  a  matrix 

The  following  example  shows  how  to  re-dimension  a  vector  of  6  elements  into 
a  matrix  of  2  rows  and  3  columns  in  ALG  mode: 


in  RPN  mode,  we  can  use  L  1  ?  3;i  4;i  Dj  6  J  (mh)  {  2  5  3}  [waj  R£m  to 
produce  the  matrix  shown  above. 


Re-dimensioning  a  matrix  into  another  matrix 

In  ALG  mode,  we  now  use  the  matrix  created  above  and  re-dimension  it  into  a 
matrix  of  3  rows  and  2  columns: 


RDM(RHS(1M3  2» 


In  RPN  mode,  we  simply  use  {  3?  2 > [enter}  RDM. 


Re-dimensioning  a  matrix  into  a  vector 

To  re-dimension  a  matrix  into  a  vector,  we  use  as  arguments  the  matrix 
followed  by  a  list  containing  the  number  of  elements  in  the  matrix.  For 
example,  to  convert  the  matrix  from  the  previous  example  into  a  vector  of 
length  6,  in  ALG  mode,  use: 
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RDM(RHS(1M3  2» 


It  D  bJ 


If  using  RPN  mode,  we  assume  that  the  matrix  is  in  the  stack  and  use  \  6/ 


Note:  Function  RDM  provides  a  more  direct  and  efficient  way  to  transform  lists 
to  arrays  and  vice  versa,  than  that  provided  at  the  end  of  Chapter  9. 

Function  RANM 

Function  RANM  (RANdom  Matrix)  will  generate  a  matrix  with  random  integer 
elements  given  a  list  with  the  number  of  rows  and  columns  (i.e.,  the 
dimensions  of  the  matrix).  For  example,  in  ALG  mode,  two  different  2x3 
matrices  with  random  elements  are  produced  by  using  the  same  command, 
namely,  RF-iNHO!  2?  3}  )  : 


:RflHMK2  3» 

[-5  -7  -91 

I  2   5   0  J 

:RflHM({2  3» 

r-4  9  41 

1-9  -5  SJ 

In  RPN  mode,  use  {2,3}  l»r«J  RrlNM. 

Obviously,  the  results  you  will  get  in  your  calculator  will  most  certainly  be 
different  than  those  shown  above.  The  random  numbers  generated  are 
integer  numbers  uniformly  distributed  in  the  range  [-10,10],  i.e.,  each  one  of 
those  21  numbers  has  the  same  probability  of  being  selected.  Function 
RANM  is  useful  for  generating  matrices  of  any  size  to  illustrate  matrix 
operations,  or  the  application  of  matrix  functions. 


Function  SUB 

Function  SUB  extracts  a  sub-matrix  from  an  existing  matrix,  provided  you 
indicate  the  initial  and  final  position  of  the  sub-matrix.  For  example,  if  we 
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want  to  extract  elements  ai2/  o^,  O22,  and  023  from  the  lost  result,  as  a  2x2 
sub-matrix,  in  ALG  mode,  use: 


I  ^   z>   a  J 

:RflHMK2  3» 

[-4  9  41 

1-9  -5  SJ 

:SUE(RHS(1M1 

2>,{2  3» 

r  9  41 

1-5  sJ 

GET  IGETII  PUT  |  PUTI  |  SUE  |  REPL 

In  RPN  mode,  assuming  that  the  original  2x3  matrix  is  already  in  the  stack, 
use  i  1 ,  2}        <  2,  3>  SUB. 


Function  REPL 

Function  REPL  replaces  or  inserts  a  sub-matrix  into  a  larger  one.  The  input  for 
this  function  is  the  matrix  where  the  replacement  will  take  place,  the  location 
where  the  replacement  begins,  and  the  matrix  to  be  inserted.  For  example, 
keeping  the  matrix  that  we  inherited  from  the  previous  example,  enter  the 
matrix:  L  l  1  n  2.  n  3  j  h  L  4  ?  5  5  6  ]  n  l  7  ?  S  5  9  j  j  .  In  ALG  mode,  the  following 
screen  shot  to  the  left  shows  the  new  matrix  before  pressing  (.intek)  .    The  screen 
shot  to  the  right  shows  the  application  of  function  RPL  to  replace  the  matrix  in 
RNSf  2  i^,  the  2x2  matrix,  into  the  3x3  matrix  currently  located  in  i-iHS':!  1  > , 
starting  at  position  •.  2?  2}  : 


4  5  6 

I7  s  9J 

REPL(RHS(1),{2  2>,RHS(2)) 
■1  2  31 
|4  9  4 
[7  -5  sJ 


GET    GETI    PUT    PUTI    SUP  REPL 


If  working  in  the  RPN  mode,  assuming  that  the  2x2  matrix  was  originally  in 
the  stack,  we  proceed  as  follows: 

r  L  1       3 1  ■!  L  4  ;i  5  ;i  b  J  s  L  7  J  3  5  9 11  J  |£N7h)(JD  (this  last  key  swaps  the 
contents  of  stock  levels  1  and  2)  {  1  ?  2}  [inter]  CD  (another  swapping  of 
levels  1  and  2)  REPL. 
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Function  ^DIAG 

Function  ^DIAG  takes  the  main  diagonal  of  a  square  matrix  of  dimensions 
nxn,  and  creates  a  vector  of  dimension  n  containing  thie  elements  of  tfie  main 
diagonal.  For  example,  for  the  matrix  remaining  from  the  previous  exercise, 


It' 

:REPL(RHS(1),{2  2}, 

RHS(2)) 

2  31 

9  4 

-5  SJ 

:-*DIRG(RHS(l)) 

[1 

9  S] 

-«IHa|DIAa-HVAnDE|HILEE|  IHATRX 

In  RPN  mode,  v/ith  the  3x3  matrix  in  the  stack,  we  simply  have  to  activate 
function  ^DIRG  to  obtain  the  same  result  as  above. 


Function  DIAG^ 

Function  DIAG->  takes  a  vector  and  a  list  of  matrix  dimensions  {rov/s, 
columns},  and  creates  a  diagonal  matrix  with  the  main  diagonal  replaced 
with  the  proper  vector  elements.  For  example,  the  command 

produces  a  diagonal  matrix  with  the  first  3  elements  of  the  vector  argument: 


-«IAa  DIAG-HVAnDE  HILEE 


In  RPN  mode,  we  can  use  [  1  j  - 1  j  2  j  3 11  Iwraj  {  3  j  3  >  [entir]  D  I  RG  ^  to 
obtain  the  same  result  as  above. 


Another  example  of  app  ication  of  the  DIAG^  function  follows,  in  ALG  mode: 
lDlHLi-*lLl     a  4  5J, 


In  RPN  mode,  use 


In  this  case  a  3x2  matrix  was  to  be  created  using  as  main  diagonal  elements 
as  many  elements  as  possible  form  the  vector  [1,2,3,4,5].  The  main  diagonal, 
for  a  rectangular  matrix,  starts  at  position  (1,1)  and  moves  on  to  position  (2,2), 
(3,3),  etc.  until  either  the  number  of  rows  or  columns  is  exhausted.  In  this 
case,  the  number  of  columns  (2)  was  exhausted  before  the  number  of  rows  (3), 
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so  the  main  diagonal  included  only  the  elements  in  positions  (1,1)  and  (2,2). 
Thus,  only  the  first  two  elements  of  the  vector  were  required  to  form  the  main 
diagonal. 


Function  VANDERMONDE 

Function  VANDERMONDE  generates  the  Vandermonde  matrix  of  dimension  n 
based  on  a  given  list  of  input  data.  The  dimension  n  is,  of  course,  the  length 
of  the  list.    If  the  input  list  consists  of  objects  {x,,  X2,...  x^},  then,  a 
Vandermonde  matrix  in  the  calculator  is  a  matrix  made  of  the  following 
elements: 


2 

n 

X,  ■ 

■■  ^1 

2 

n 

X2 

X2 

X2 

2 

n 

X3 

2 

n 

For  example,  the  following  command  in  ALG  mode  for  the  list  {1,2,3,4}: 


iVflhJDERMOHDEK 

1  2  3  4» 

111  11 

12  4  3 
1  3  9  27 
.1  4  16  64J 

-«IHa|DIAa-HVAnDE|HILEE|  IHATRX 

In  RPN  mode,  enter  {  J. «.  2?  B?  4>  [mh)  vRHDERMuNDE  . 
Function  HUBERT 

Function  HUBERT  creates  the  Hilbert  matrix  corresponding  to  a  dimension  n. 
By  definition,  the  nxn  Hilbert  matrix  is      =  [hjj^xn/  so  that 
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The  Hilbert  matrix  has  application  in  numerical  curve  fitting  by  the  method  of 
linear  squares. 

A  program  to  build  a  matrix  out  of  a  number  of  lists 

In  this  section  we  provide  a  couple  of  UserRPL  programs  to  build  a  matrix  out 
of  a  number  of  lists  of  objects.  The  lists  may  represent  columns  of  the  matrix 
(program  HSIH)  or  rows  of  the  matrix  (program  HJCH).  The  programs  are 
entered  with  the  calculator  set  to  RPN  mode,  and  the  instructions  for  the 
keystrokes  are  given  for  system  flag  1  1 7  set  to  SOFT  menus.  This  section  is 
intended  for  you  to  practice  accessing  programming  functions  in  the  calculator. 
The  programs  are  listed  below  showing,  in  the  left-hand  side,  the  keystrokes 
necessary  to  enter  the  program  steps,  and,  in  the  right-hand  side,  the 
characters  entered  in  the  display  as  you  perform  those  keystrokes.  First,  we 
present  the  steps  necessary  to  produce  program  CRMC. 

Lists  represent  columns  of  the  matrix 

The  program  allows  you  to  put  together  a  pxn  matrix  (i.e.,  p  rows,  n 
columns)  out  of  n  lists  of  p  elements  each.   To  create  the  program  enter  the 

Produces: 

DUP 
^  n 

« 

1  SWAP 
FOR 

i 

OBJ^ 
^ARRY 
IF 

i 

n 

< 

THEN 

ii  + 

ROLL 
END 


following  keystrokes: 

Keystroke  sequence: 

CT^D   « » 

r^izr^  par  iKifKi'g-nE  Bin'nT:^! 
l^_l_J  rnu^  iE:il.B.iji3.ui  BiLiiUiiisI 

— ^  Lspcj  [alpha)  [JjJ(n] 

QDfflc_l0Ml  iSSM 

(alpha}(j^(]] 

r  ^  "I  nor  in'Fi'Pia'ni  iie'tsid  iiST3i 
l__n_J  iLiLiJi:3.Lii   iiE.3.BiQ  iiE^M 

r  ^  1  nor  iirif  i^iai-ai  iibifiibib 
l__n_J  llllL:z:di Ji  iiHiuiiiH 

(3I]«_injMgj^js:[jiii:i 
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r~4^^r^  par      in'ri'Pia'nr   ii-ii^T'BiE  inTTiii-a 
L_2lLJ  ,         iL:ILiiia.sji   ii Ji^iu:!!!   iU.L:3.iJi J 

NEXT 

{   4^   y  nor        iilTi'ria'ni     iiE'3'3ii  Sir:i'=!BiE 

l__n_J  ,         iLiLiiia-Lii   iiE-xnii  uLiLHiiiE 

IF 

n  1 

> 

[jn^WG     iiSSiilii  lllliNlEil  iN"-" 

THEN 

1 

n  1  ■ 

r~^^r~l  Pffr      in'rivia-ni   ii-ii^T'BiE  in:p:T:iiE 
l^__XJ ,  "      iLiliiia-Lii   ii ji^iu:iiE  iEJiEilJ-iJii 

FOR 

i 

i  1  + 

ROLL 

[jT]fflG  iiiiiirni  iriEni  in=!T!rii 

NEXT 

CjnD™G_  1111111  liigE  iiai 

END 

n 

COL^ 

IfNTsJ  Program  is  displayed  in  level  1 


To  save  the  program:  {_jJi\Aimf;i{^^(c\(R\i^^[MPH^  (TroT) 

Note:  if  you  save  this  program  in  your  HOME  directory  it  will  be  available 
from  any  other  sub-directory  you  use. 


To  see  the  contents  of  the  program  use  I  j  [  r»  JIHfljB.  The  program  listing  is 
the  following: 

  -J  !  I  i~i  r"i    !"■■  :"'s  !~i      1     {"i  l"i    I  T'l  l~i  T'l '. .'     T  T"      1     _.      .-'     "!"  i  ! !""  L  E      J      -I  i 

■  -»  n      i.  oi-ynr  ri..ir:.  ..i  ud'-j^  ->nr:.r':.  i    ir  .j  m  \    iriE::ii  j  i  t 

"■■".Si".  L  !""■=..' ■T   T  I—  _.    -I    \    "n  jr"|.  I  H    _    <  i    -    ■!    _!_  nr"ii  I 

..  !:::!  ■!!...■  !  ■!!::.:■■:!    j.  r  ii  i  y    i  ricN  i  ii  i  —  ruK  ..]  ..i  i  +  Klji_l. 

■■  r-  L  I  r-.  _.    I".  i™i  I         ..^  V. 

[■rii.."  i  i  i_.L.ii_->  'y 


To  use  this  program,  in  RPN  mode,  enter  the  n  lists  in  the  order  that  you  want 
them  as  columns  of  the  matrix,  enter  the  value  of  n,  and  press  BSHa.  As  an 
example,  try  the  following  exercise: 

{  1 ,     3;,  4>        {  1 ,  4,  9,  16>  1^  {  1 ,  8,  27;,  64>         3  HSila 


The  following  screen  shots  show  the  RPN  stack  before  and  after  running 
program  [ 


J- 

4: 

a  2  3  4) 

3: 

{14  9  16) 

2: 

{1  3  27  64) 

l: 

3 

l: 

ri  1  1 

2  4  3 

3  9  27 

.4  16  64. 
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To  use  the  program  in  ALG  mode,  press  EEH  followed  by  a  set  of  parentheses 

(1*1 } 'J.  ).    Within  the  parentheses  type  the  lists  of  data  representing  the 

columns  of  the  matrix,  separated  by  commas,  and  finally,  a  comma,  and  the 
number  of  columns.    The  command  should  look  like  this: 


The  ALG  screen  showing  the  execution  of  program  CRMC  is  shown  below: 


iCRMCta  2  3  4M1 

4 

?  1 

6},* 

fl 

1 

2 

4 

3 

3 

9 

27 

.4 

16 

64. 

HYP  |Hi:0£2|H£in2|H£in2|HTAn2|HHLFT 

Lists  represent  rows  of  the  matrix 

The  previous  program  can  be  easily  modified  to  create  a  matrix  when  the 
input  lists  will  become  the  rows  of  the  resulting  matrix.  The  only  change  to  be 
performed  is  to  change  COL^  for  ROW->  in  the  program  listing.  To  perform 
this  change  use: 


<^  CZD  ^  ^  CD  CD  CD 

(^™)  1^1™)  (?]  (§]  (gi  (^t^ 


List  program  CRMC  in  stack 
Move  to  end  of  program 
Delete  COL 

Type  in  ROW,  enter  program 


To  store  the  program  use:  dJ(^^(^^©(3i<Si(3i(^!^ 


{1,2,  3,  4>  {  1 ,  4,  9,  16>  -J  1 , 8,  27,  64>  3  SaSia 
The  following  screen  shots  show  the  RPN  stack  before  and  after  running 
program  jyiiiiE: 


4: 

a.  2.  3.  4.) 

3: 

a.  2.  9.  16.) 

2: 

{1.  S.  27.  64.) 

l: 

3. 

CRHRlCRHCl         1         1  1 

l: 

2. 

3. 

4.  1 

11; 

2. 

9. 

16. 

3. 

27. 

64.  J 

CRHRlCRHCl         1         1  1 

These  programs  can  be  useful  for  statistical  applications,  specifically  to  create 
the  statistical  matrix  SDAT.  Examples  of  the  use  of  these  program  are  shown 
in  a  latter  chapters. 
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Manipulating  matrices  by  columns 

The  calculator  provides  a  menu  with  functions  for  manipulating  matrices  by 
operating  in  their  columns.  This  menu  is  available  through  the 
MTH/MATRIX/COL..  sequence:  (CjT]*™_  )  shov/n  in  the  figure  below  with 
system  flog  1  1 7  set  to  CHOOSE  boxes: 


HHTH  HEnU 

1.  VECTOR..  1 

a.MflTRIK.. 

3.  LIST.. 
H.HYPEREOLIC. 
5.REHL.. 
e.EASE.. 

1       1       1  IcflncL 

OK 

HATRIX  HERU 

l.HAKE..  1 

a.nORHALIZE.. 

3.  FACTORS.. 

H.COL.. 

5.R0H.. 

1         1  1 

ICARCL 

OK 

or  through  the  MATRICES/CREATE/COLUMN  sub-menu: 


HATRICES  HERU 


a.OPERATIOnS.. 
3.FACT0RIZATI0n.. 
H. QUADRATIC  FORM.. 
S.LIREAR  SVSTEHS.. 
e.LIREAR  ARPL.. 


Both  approaches  will  show  the  some 


HATRIK  CREATE  HERU 

a.ROH.. 

3.AUCHEnT 

H.IDR 

5.  con 

e.-4IAG 

1         1         1  ICARCL 

OK 

CREATE  COL  HERU 

1.<0L 

a.coL-f 

3.C0L+ 

H.COL- 

5.CSHP 

HATRIK.. 

1         1         1  ICARCLl 

OK 

unctions: 


CREATE  COL  HERU 

1.<0L 

a.coL+ 

3.C0L+ 

H.COL- 

5.CSHP 

CREATE.. 

1         1         1  ICARCLl 

OK 

When  system  flag  1  1 7  is  set  to  SOFT  menus,  the  COL  menu  is  accessible 
through  CHD^ZW-  [liiS33EiIa3l  SE^IH  ,  or  through  rW]MAmas  S@33J0S  SB33II .  Both 
approaches  will  show  the  same  set  of  functions:  


-H:0L   COL-f  COL+   COL-   CSHP  HATRK 


-H:0L   COL-f  COL+   COL-   CSHP  CREAT 


The  operation  of  these  functions  is  presented  below. 


Function  ^COL 

Function  ^COL  takes  as  argument  a  matrix  and  decomposes  it  into  vectors 
corresponding  to  its  columns.  An  application  of  function  ^COL  in  ALG  mode 
is  shown  below.  The  matrix  used  has  been  stored  earlier  in  variable  A.  The 
matrix  is  shown  in  the  figure  to  the  left.  The  figure  to  the  right  shows  the  matrix 
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decomposed  in  columns.  To  see  the  full  result,  use  the  line  editor  (triggered 
by  pressing  ).  


:R 

-2.54.2  2. 

.3  1.92.31 
.2.  -.1.5 

{[-2.5  .3  2.]  [4.2  1.9  -. 


T 


T3    1.9  2. a 
2.    -.1  .5 
■^COLtR) 
{[-2.5  .3  2.]  [4.2  1.9  -. 
C[-2.5, .3,2. ], 
[4.2, 1.9,-. 1], 
[2. ,2.3, .5], 3. y 


1 


t^KIP  SKIP-H  H)EL   DEL-f  DEL  L   inS  M+^KIP  SKIPH  H)EL   DEL-f  DEL  L  IDS  i 


in  RPN  mode,  you  need  to  list  the  matrix  in  the  stock,  and  the  activate  function 
^COL,  i.e.,  S3SS  ^COL.  The  figure  below  shows  the  RPN  stack  before  and 
after  the  application  of  function  ^COL. 


4: 
3: 
2: 
l: 


-2.5  4.2  2. 
.3  1.92.31 
2.  -.1.5 


CRHR  CRHC 


/: 

5: 

5: 

4: 

[-2.5  .32.] 

3: 

[4.2  1.9  -.  1] 

2: 

[2.  2.3  .5] 

l: 

3. 

■«!L 

COL-f|  CDL+  1  COL-  1  CSHP  IMflTRK 

In  this  result,  the  first  column  occupies  the  highest  stack  level  after 
decomposition,  and  stack  level  1  is  occupied  by  the  number  of  columns  of  the 
original  matrix.  The  matrix  does  not  survive  decomposition,  i.e.,  it  is  no 
longer  available  in  the  stack. 


Function  COL^ 

Function  COL->  has  the  opposite  effect  of  Function  ^COL,  i.e.,  given  n 
vectors  of  the  same  length,  and  the  number  n,  function  COL^  builds  a  matrix 
by  placing  the  input  vectors  as  columns  of  the  resulting  matrix.  Here  is  an 
example  in  ALG  mode.  The  command  used  was: 
COL^Ci: 


:,9:],3;' 

:C0L-*([1.  2.  3.] 

i 

4.  7.1 

5.  3. 

6.  9. J 

In  RPN  mode,  place  the  n  vectors  in  stock  levels  n+1,  n,  n-l,...,2,  and  the 
number  n  in  stock  level  1 .  With  this  set  up,  function  COL^  places  the  vectors 
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as  columns  in  the  resulting  matrix.  The  following  figure  shows  the  RPN  stack 
before  and  after  using  function  COL^. 


4: 

[1. 

2. 

3.] 

3: 

[4. 

5. 

6.1 

Z: 

[7. 

3. 

3.1 

l: 

3. 

CRHR  CRHC 


2: 

l: 

4. 

5. 

3. 

Is. 

6. 

3.1 

CRHR  1  CRHC  1    H    1         |  | 

Function  COL+ 

Function  COL+  takes  as  argument  a  matrix,  a  vector  with  the  some  length  as 
the  number  of  rows  in  the  matrix,  and  an  integer  number  n  representing  the 
location  of  a  column.  Function  COL+  inserts  the  vector  in  column  n  of  the 
matrix.  For  example,  in  ALG  mode,  we'll  insert  the  second  column  in  matrix  A 
with  the  vector  [-1,-2,-3],  i.e.,  


iCOL-KFlI-l. 

-2. 

-3.],2.) 

[-2.5 

-1. 

4.2  2.  1 

-2. 

1.9  2.3 

-3. 

-.  1  .5  J 

CRHR  1  CRHC  1    HI         |  | 

In  RPN  mode,  enter  the  matrix  first,  then  the  vector,  and  the  column  number, 
before  applying  function  COL-I-.  The  figure  below  shows  the  RPN  stack  before 
and  after  applying  function  COL-i-. 


Function  COL- 

Function  COL-  takes  as  argument  a  matrix  and  an  integer  number  representing 
the  position  of  a  column  in  the  matrix.  Function  returns  the  original  matrix 
minus  a  column,  as  well  as  the  extracted  column  shown  as  a  vector.  Here  is 
an  example  in  the  ALG  mode  using  the  matrix  stored  in  A: 


C0L-(R.3.) 
[-2.5  4.21 

3    1.9  [2.  2.3  .5]^ 


ir 


2.    -.  1 


CRHR  CRHC 
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In  RPN  mode,  place  the  matrix  in  the  stack  first,  then  enter  the  number 
representing  a  column  location  before  applying  function  COL-.  The  following 


r-2.5  4. 

2  2.  1 

.3  1. 

9  2.3 

I  2.  -. 

1   .5  J 

l:   

3. 

CRHR  1  CRHC  1    H    1         |  | 

CRHR  CRHC 


Function  CSWP 

Function  CSWP  (Column  SWaP)  takes  as  arguments  two  indices,  say,  i  and  j, 
(representing  two  distinct  columns  in  a  matrix),  and  a  matrix,  and  produces  a 
new  matrix  with  columns  i  and  j  swapped.   The  following  example,  in  ALG 
mode,  shows  an  application  of  this  function.  We  use  the  matrix  stored  in 
variable  A  for  the  example.  This  matrix  is  listed  first. 


CRHR  CRHC 


In  RPN  mode,  function  CSWP  lets  you  swop  the  columns  of  a  matrix  listed  in 
stack  level  3,  whose  indices  are  listed  in  stack  levels  1  and  2.  For  example, 
the  following  figure  shows  the  RPN  stack  before  and  after  applying  function 
CSWP  to  matrix  A  in  order  to  swap  columns  2  and  3: 


CRHR  CRHC 


CRHR  CRHC 


As  you  can  see,  the  columns  that  originally  occupied  positions  2  and  3  have 
been  swapped.  Swapping  of  columns,  and  of  rows  (see  below),  is  commonly 
used  when  solving  systems  of  linear  equations  with  matrices.  Details  of  these 
operations  will  be  given  in  a  subsequent  Chapter. 


Manipulating  matrices  by  rows 

The  calculator  provides  a  menu  with  functions  for  manipulating  matrices  by 
operating  in  their  rows.  This  menu  is  available  through  the 
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MTH/MATRIX/ROW..  sequence:  (CjnDilZW-  )  shown  in  the  figure  below  with 


system  f 


gq  1  1 7  set  to  CHOOSE  boxes 


HATH  HEnU 


ly  ECTOR.. 

3.  LIST.. 
H.HYPEREOLIC. 
5.  REAL.. 
e.EASE.. 


or  through  the  MATRICES/CREATE/ROW  sub-menu 


MATRIX  HERU 

1.  HAKE..  1 

2.  nORHALIZE.. 

3.  FACTORS.. 
H.COL.. 

5.  RON..  1 

1    1  1 

ICARCL 

OK 

MATRICES  HERU 


OPERATIOnS.. 
FACTORIZATIOn.. 
QUADRATIC  FORM.. 
LIREAR  SYSTEMS.. 
LIREAR  APPL.. 


Both  approaches  will  show  the  same 


CREATE  ROM  HERU 


2.  R0H-» 

3.  R0H+ 
H.ROH- 
5.RCI 
e.RCIJ 


unctions: 


MATRIX  CREATE  MERU 

^.AUCMERT 
H.IDR 

5.  con 

e.-4IAG 

1         1         1  ICARCL 

OK 

CARCL  OK 


CREATE  ROM  MERU 

l.-tfiOH 

2.R0H-» 

3.R0H+ 

H.ROH- 

5.RCI 

e.RCIJ 

1         1         1  ICARCLl 

OK 

When  system  flag  1 1 7  is  set  to  SOFT  menus,  the  ROW  menu  is  accessible 
through  CTD«Zw_i:;]!ijiM^^  or  throuqh  QD(!««»5^SSa]EBIS  SuSHII.  Both 

approaches  will  show  the  same  set  of  functions: 


■^t■.<m  I  ROH-»|  ROH+  I  ROM-  |  RCI  |  RCIJ 


The  operation  of  these  functions  is  presented  below. 
Function  ^ROW 

Function  ^ROW  takes  as  argument  a  matrix  and  decomposes  it  into  vectors 
corresponding  to  its  rows.  An  application  of  function  ^ROW  in  ALG  mode  is 
shown  below.  The  matrix  used  has  been  stored  earlier  in  variable  A.  The 
matrix  is  shown  in  the  figure  to  the  left.  The  figure  to  the  right  shows  the  matrix 
decomposed  in  rows.  To  see  the  full  result,  use  the  line  editor  (triggered  by 
pressing  ^[j? ). 
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:R 

[-2.5  4. 

2  2.  1 

.3  1. 

9  2.3 

I  2.  -. 

1   .5  J 

{[-2.  54. 

2  2.]  [.3  1 

.9  2.  ► 

CRHR  1  CRHC  1    H    1         |  | 

I  2.  -.1 

{[-2.5  4.2  2.]  [.3  1.9  2.  H 
+[-2.5,4.2,2. ], 
[.3, 1.9,2.3], 
[2. ,-. 1, .5],3. J 


t^KIP  SKIPH  H)EL   DEL-f  DEL  L  inS  i 


In  RPN  mode,  you  need  to  list  the  matrix  in  the  stack,  and  the  activate  function 
^ROW,  i.e.,  111111  ^ROW.  The  figure  below  shows  the  RPN  stock  before 


and  after  the  application  of  function  ^ROW. 


2: 

-2.5  4. 

2  2.  1 

'  1 

.3  1. 

9  2.3 

2.  -. 

1  .5  J 

CRHR  1  CRHC  1    HI         |  | 

4: 

[-2.5  4.2  2.] 

3: 

[.3  1.9  2.3] 

2: 

[2.  -.1  .5] 

l: 

3. 

CRHR  1  CRHC  1    HI         |  | 

In  this  result,  the  first  row  occupies  the  highest  stack  level  after  decomposition, 
and  stack  level  1  is  occupied  by  the  number  of  rows  of  the  original  matrix. 
The  matrix  does  not  survive  decomposition,  i.e.,  it  is  no  longer  available  in  the 
stack. 


Function  ROW^ 

Function  ROW^  has  the  opposite  effect  of  the  function  ^ROW,  i.e.,  given  n 
vectors  of  the  same  length,  and  the  number  n,  function  ROW^  builds  a 
matrix  by  placing  the  input  vectors  as  rows  of  the  resulting  matrix.  Here  is  an 
example  in  ALG  mode.  The  command  used  was: 


:R0W-*([1.  2.  3.] 

14.  5.  6* 
1.  2.  3.1 
4.  5.  6. 
.7.  3.  9.  J 

+^KIP|SKIP^  H)EL  1  DEL- 

MDEL  L|in£> 

In  RPN  mode,  place  the  n  vectors  in  stack  levels  n+1,  n,  n-l,...,2,  and  the 
number  n  in  stack  level  1 .  With  this  set  up,  function  ROW^  places  the 
vectors  as  rows  in  the  resulting  matrix.  The  following  figure  shows  the  RPN 
stack  before  and  after  using  function  ROW^. 
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4: 

[1. 

2. 

3.] 

3: 

[4. 

5. 

6.1 

2: 

[7. 

S. 

S.l 

l: 

3. 

CRHR  CRHC 


l: 

ri.  2. 

4.  5. 

l;l 

17.  S. 

+^KIP|SKIP-t 

1  H)EL  1  DEL-f|DEL  L| 

ins  ■ 

Function  ROW+ 

Function  ROW+  takes  as  argument  a  matrix,  a  vector  with  the  same  length  as 
the  number  of  rows  in  the  matrix,  and  an  integer  number  n  representing  the 
location  of  a  row.  Function  ROW+  inserts  the  vector  in  row  n  of  the  matrix. 
For  example,  in  ALG  mode,  we'll  insert  the  second  row  in  matrix  A  with  the 
vector  [-1,-2,-3],  i.e.,   


:R0W-KR,[-1 

.  -2. 

-3.].2.) 

[-2.5  4.2  2.  1 

-1. 

-2.  -3. 

.3 

1.9  2.3 

.  2. 

-.1   .5  J 

CRHR  1  CRHC  1    H    1         |  | 

In  RPN  mode,  enter  the  matrix  first,  then  the  vector,  and  the  row  number, 
before  applying  function  ROW-i-.  The  figure  below  shows  the  RPN  stack 
before  and  after  applying  function  ROV/+. 


Function  ROW- 

Function  ROW-  takes  as  argument  a  matrix  and  an  integer  number 
representing  the  position  of  a  row  in  the  matrix.  The  function  returns  the 
original  matrix,  minus  a  row,  as  well  as  the  extracted  row  shown  as  a  vector. 
Here  is  an  example  in  the  ALG  mode  using  the  matrix  stored  in  A: 


11 


R0W-(R.3.) 
-2.5  4.2  2.  1  rr> 
3    1.9  2.  SJ'-^-  ■ 


1  .  t 


CRHR  CRHC 


In  RPN  mode,  place  the  matrix  in  the  stack  first,  then  enter  the  number 
representing  a  row  location  before  applying  function  ROW-.  The  following 
figure  shows  the  RPN  stack  before  and  after  applying  function  ROW-. 
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R0W-(R.3.) 
-2.5  4.2  2.  1 
3    1.9  2. SJ 
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Function  RSWP 

Function  RSWP  (Row  SWaP)  takes  as  arguments  two  indices,  say,  i  and  j, 
(representing  two  distinct  rows  in  a  matrix),  and  a  matrix,  and  produces  a 
new  matrix  with  rows  i  and  j  swapped.   The  following  example,  in  ALG 
mode,  shows  an  application  of  this  function.  We  use  the  matrix  stored  in 
variable  A  for  the  example.  This  matrix  is  listed  first. 


In  RPN  mode,  function  CSWP  lets  you  swap  the  rows  of  a  matrix  listed  in 
stack  level  3,  whose  indices  are  listed  in  stack  levels  1  and  2.  For  example, 
the  following  figure  shows  the  RPN  stack  before  and  after  applying  function 


CRMR  CRMC 


2: 

l: 

r-2.5  4.2  2.  1 

2.  -.1.5 

1.3    1.9  2. 3J 

CRMR  1  CRMC  1    H    1         |  | 

As  you  can  see,  the  columns  that  originally  occupied  positions  2  and  3  have 
been  swapped. 


Function  RCI 

Function  RCI  stands  for  multiplying  Row  I  by  a  Constant  value  and  replace  the 
resulting  row  at  the  same  location.   The  following  example,  written  in  ALG 
mode,  takes  the  matrix  stored  in  A,  and  multiplies  the  constant  value  5  into 
row  number  3,  replacing  the  row  with  this  product. 


.3  1.92.31 
2.    -.1  .5 
RCI(R,5.,3.) 

T-2.54.2  2. 
.3  1.92.31 
10.  -.52. 


CRMR  CRMC 
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This  same  exercise  done  in  RPN  mode  is  shown  in  the  next  figure.  The  left- 
hand  side  figure  shows  the  setting  up  of  the  matrix,  the  factor  and  the  row 
number,  in  stack  levels  3,  2,  and  1 .  The  right-hand  side  figure  shows  the 


■t' 

3: 

2: 

l: 

r-2.5  4.2  2.  1 

.3  1.92.3 

L 10.  -.5  2.5J 

CRHR  1  CRHC  1    HI         |  | 

Function  RCIJ 

Function  RCIJ  stands  for  "take  Row  I  and  multiplying  it  by  a  constant  C  and 
then  add  that  multiplied  row  to  row  J,  replacing  row  J  with  the  resulting  sum." 
This  type  of  row  operation  is  very  common  in  the  process  of  Gaussian  or 
Gauss-Jordan  elimination  (more  details  on  this  procedure  are  presented  in  a 
subsequent  Chapter).  The  arguments  of  the  function  are:  (1)  the  matrix,  (2) 
the  constant  value,  (3)  the  row  to  be  multiplied  by  the  constant  in(2),  and  (4) 
the  row  to  be  replaced  by  the  resulting  sum  as  described  above.  For  example, 
taking  the  matrix  stored  in  variable  A,  we  are  going  to  multiply  column  3 
times  1 .5,  and  add  it  to  column  2.  The  following  example  is  performed  in 
ALG  mode: 


:kuijih,i 

■                ■    1^  ■  J 

r-2.5  4.2   2.  1 
3.3  1.753.55 
.2.    -.1    .5  J 

CRHR  1  CRHC  1    HI         |  | 

In  RPN  mode,  enter  the  matrix  first,  followed  by  the  constant  value,  then  by 
the  row  to  be  multiplied  by  the  constant  value,  and  finally  enter  the  row  that 
will  be  replaced.  The  following  figure  shows  the  RPN  stack  before  and  after 
applying  function  RCIJ  under  the  same  conditions  as  in  the  ALG  example 
shown  at 


Dove: 

4: 

r-2.5  4. 

2  2.  1 

.3  1. 

9  2.3 

I  2.  -. 

1  .5  J 

3: 

1.5 

2: 

3. 

l: 

2. 

CRHR  1  CRHC  1    H    1         |  | 

3: 

4: 

3: 

2: 

l: 

[-2.5 

4.2    2.  1 

I  If 

1.75  3.55 

-.1     .5  J 

CRHR  1  CRHC  1    H    1         |  | 
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Chapter  1 1 

Matrix  Operations  and  Linear  Algebra 

In  Chapter  10  we  introduced  the  concept  of  a  matrix  and  presented  a  number 
of  functions  for  entering,  creating,  or  manipulating  matrices.  In  this  Chapter 
we  present  examples  of  matrix  operations  and  applications  to  problems  of 
linear  algebra. 

Operations  with  matrices 

Matrices,  like  other  mathematical  objects,  can  be  added  and  subtracted. 
They  can  be  multiplied  by  a  scalar,  or  among  themselves.  An  important 
operation  for  linear  algebra  applications  is  the  inverse  of  a  matrix.  Details  of 
these  operations  are  presented  next. 

To  illustrate  the  operations  we  will  create  a  number  of  matrices  that  we  will 
store  in  variables.  The  generic  name  of  the  matrices  will  be  A//'  and  B//, 
where  /  represents  the  number  of  rows  and  /  the  number  of  columns  of  the 
matrices.  The  matrices  to  be  used  ore  generated  by  using  function  RANM 
(random  matrices).  If  you  try  this  exercise  in  your  calculator  you  will  get 
different  matrices  than  the  ones  listed  herein,  unless  you  store  them  into  your 
calculator  exactly  as  shown  below.  Here  are  the  matrices  A22,  B22,  A23, 
B23,  A32,  B32,  A33  and  B33  created  in  ALG  mode: 


IS  0] 

10  3\ 

r?  -s-i 

l-s  s  J 

l-s  s  J 

IS  6  5] 
l-l  H  SJ 

3JJ^Ra3 

10  H  -HI 
16  -6  -Si 

In  RPN  mode,  the  steps  to  follow  are: 

y  [ento}     f^         n  .  .  (sroT) 
■;  ;■  [ento)  '  nP.3  '  [sjo*j 

■:.}  [enter)  RFiNM  '  n32  ' 


[ENTER) 

(enter) 
[enter) 
[enter] 


B  !:::!!•:!  '  [sto*J 
323  '  [sToyj 

633 ' 
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Addition  and  subtraction 

Consider  a  pair  of  matrices  A  =  [OiJ^ixn  and  B  =  [bij^xn-  Addition  and 
subtraction  of  tfiese  two  matrices  is  only  possible  if  tfiey  have  tfie  same 
number  of  rows  and  columns.  The  resulting  matrix,  C  =  A  ±  B  =  [cijl^xn  has 
elements  C|j  =  0,1  ±  bjj.  Some  examples  in  ALG  mode  are  shown  below  using 
the  matrices  stored  above  (e.g.,  E:BiL±J  IueO)  


Translating  the  ALG  examples  to  RPN  is  straightforward,  as  illustrated  here. 
The  remaining  examples  of  matrix  operations  will  be  performed  in  ALG  mode 
only. 

Multiplication 

There  are  different  multiplication  operations  that  involve  matrices.  These  are 
described  next. 

Multiplication  by  a  scalar 

Multiplication  of  the  matrix  A  =  [OjiJ^xn  by  a  scalar  k  results  in  the  matrix  C  = 
l<A  =  [Cjil^xn  =  [ka|j]^xn-    In  particular,  the  negative  of  a  matrix  is  defined  by 
the  operation  -A  =(-1  )A  =  [-Oy^  ^xn-   Some  examples  of  multiplication  of  a 
matrix  by  a  scalar  are  shown  below. 
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:5'H32 

1 

-30 
H5 

-as 

-301 
35 
0  J 

-s 

-SSI 

[| 

HO 

-5S 

-HS 

-isJ 

|3a  HO  -SSI 

Ise  -HS  -leJ 

:-Ea3 

r  0  -H  HI 
1-6  6  Si 

:i.a5'Haa 

¥-10.    0  1 

10  a.sJ 

By  combining  addition  and  subtraction  with  multiplication  by  a  scalar  we  can 
form  linear  combinations  of  matrices  of  the  same  dimensions,  e.g., 


:E.fl33-S.E33 

r-is 

-ai 

-aai 

h 

70 

-la 

-HI 

s  J 

:-3.Ea3-?.fla3 

-5H 

-a3i 

-10 

-iiJ 

:a<Aaa- 

■'J-H22 

-?S  72  1 

[ 

72  -SSJ 

:E.fl3a- 

■n.E3a 

r  -3D 

-30-3.nl 

1  H5-5.n 

35~S.n 

l-as—H.n 

-(-3.n)J 

in  a  linear  combination  of  matrices,  we  can  multiply  a  matrix  by  an  imaginary 
number  to  obtain  a  matrix  of  complex  numbers,  e.g.. 


:a.fl33-S.i.E33 

r-is~H.s.i 

-S-S'i 

s- 

?■« 

i  1 

1  lH~H.S.i 

lS~5.S.i 

la 

-?.s 

■  i  1 

I  10~?.6.i 

-2-6.6.i 

s- 

2<S 

i  J 

r-(ie-aH.i)  -te.e) 

s 

-Ha 

i  1 

1  (iH,aH) 

(IS,  30) 

12 

-Ha 

■  i  1 

L  (10, HS) 

-(a,3S) 

s 

-la 

X  J 

COLLE  EKPfln  FflCTO  LnCOL  Lin 

PflRTF 

Matrix-vector  multiplication 

Matrix-vector  multiplication  is  possible  only  if  the  number  of  columns  of  the 
matrix  is  equal  to  the  length  of  the  vector.  This  operation  follows  the  rules  of 
matrix  multiplication  as  shown  in  the  next  section.   A  couple  of  examples  of 
matrix-vector  multiplication  follow: 


:e3a 
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Vector-matrix  multiplication,  on  the  other  hand,  is  not  defined.  This 
multiplication  can  be  performed,  however,  as  a  special  case  of  matrix 
multiplication  as  defined  next. 


Matrix  multiplication 

Matrix  multiplication  is  defined  by  C^xn  =  A^xp-Bp^n,  where  A  =  [Oijlmxp,  B  = 
[b,j]pxn,  and  C  =  [C|i]„xn-  Notice  that  matrix  multiplication  is  only  possible  if  the 
number  of  columns  in  the  first  operand  is  equal  to  the  number  of  rows  of  the 
second  operand.   The  general  term  in  the  product,  Qj,  is  defined  as 


p 

^ij  -b;^,  fori  =  1,2,..., m;j  =  1,2,..., n. 

k=i 


This  is  the  same  as  saying  that  the  element  in  the  i-th  row  and  j-th  column  of 
the  product,  C,  results  from  multiplying  term-by-term  the  i-th  row  of  A  with  the  j- 
th  column  of  B,  and  adding  the  products  together.  Matrix  multiplication  is  not 
commutative,  i.e.,  in  general,  A  B  ^  B  A.  Furthermore,  one  of  the 
multiplications  may  not  even  exist.  The  following  screen  shots  show  the  results 
of  multiplications  of  the  matrices  that  we  stored  earlier: 


r  16  31 

-631 

1-102  3 

117] 

L  -HH  3H 

36  J 

:E33.fl33 

r  ?H  13 

IS  1 

1  3a  -35 

-is\ 

16  J 

:Ha2<eaa 

r-56  6H1 
L-16  16J 

:ea2<Haa 

r-56  -161 
L  6H    16  J 

r  -6  la 

15  1 

1  5a  6 

-5 

1-36  -36 

-35J 

:ea3<H3a 

r56 

1-50 

IS  1 

-7S\ 

e3a<eaa 


ea3<H33 


[ 


-an  ani 
S3  -ssl 

.  -H  S 


130  -53  -HHJ 


The  matrix-vector  multiplication  introduced  in  the  previous  section  can  be 
thought  of  as  the  product  of  a  matrix  mxn  with  a  matrix  nxl  (i.e.,  a  column 
vector)  resulting  in  an  mxl  matrix  (i.e.,  another  vector).  To  verify  this 
assertion  check  the  examples  presented  in  the  previous  section.  Thus,  the 
vectors  defined  in  Chapter  9  are  basically  column  vectors  for  the  purpose  of 
matrix  multiplication. 
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The  product  of  a  vector  with  a  matrix  is  possible  if  the  vector  is  a  row  vector, 
i.e.,  a  Ixm  matrix,  which  multiplied  with  a  matrix  mxn  produces  a  Ixn  matrix 
(another  row  vector).  For  the  calculator  to  identify  a  row  vector,  you  must  use 
double  brackets  to  enter  it,  e.g., 


:e32 

:[1  3  EI'An^d) 

I-S  -33] 

¥0  H  -HI 

U  -fi  -sJ 

:[1  3]<An£(l) 

US  -iH  -ag] 

Term-by-term  multiplication 

Term-by-term  multiplication  of  two  matrices  of  the  same  dimensions  is  possible 
through  the  use  of  function  HADAMARD.  The  result  is,  of  course,  another 
matrix  of  the  same  dimensions.  This  function  is  available  through  Function 
catalog  (C3^  ),  or  through  the  MATRICES/OPERATIONS  sub-menu 
)■  Applications  of  function  HADAMARD  are  presented  next: 


:HADAHARD(A33,e33) 

-3 

IS} 

Vis 

-HO 

Hal 

1-35 

-e 

s  J 

:HADAHARD(Aaa^eaa) 

1 

-5S 
0 

0  1 
161 

:HADAHARD(e3a,A3a) 

120 

-IS] 

-Ha 
0  J 

:HADAHARD(ea3^Aa3) 

r  0  an 

-aoi 

l-ia  -an 

-HOJ 

The  identity  matrix 

In  Chapter  9  we  introduce  the  identity  matrix  as  the  matrix  I  =  [5ij]nxn/  where  5i| 
is  the  Kronecker's  delta  function.  Identity  matrices  can  be  obtained  by  using 
function  IDN  described  in  Chapter  9.  The  identity  matrix  has  the  property  that 
A-l  =  I'A  =  A.  To  verify  this  property  we  present  the  following  examples 
using  the  matrices  stored  earlier  on: 
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The  inverse  matrix 

The  inverse  of  a  square  matrix  A  is  the  matrix      such  that  A-A^  =  A^  A  =  I, 
where  I  is  the  identity  matrix  of  the  same  dimensions  as  A.  The  inverse  of  a 
matrix  is  obtained  in  the  calculator  by  using  the  inverse  function,  INV  (i.e.,  the 
[JixJ  key).  An  example  of  the  inverse  of  one  of  the  matrices  stored  earlier  is 
presented  next; 


inV(fl33) 


-IS  -H  35 

ans  ans  ans 

-1  as  -3S 

243  aH3  aH3 

H?  a3  H3 


To  verify  the  properties  of  the  inverse  matrix,  we  present  the  following 
multiplications: 


:fl33.inV(fl33) 

ri  0  0] 
\o  1  o\ 

10  0  iJ 

ri  0  0] 
\o  1  o\ 

10  0  iJ 

eaa<inv(eaa) 
Haa<inv(Haa) 


T 


0  101 
0  0  iJ 

ri  oi 
10  iJ 


Characterizing  a  matrix  (The  matrix  NORAA  menu) 

The  matrix  NORM  (NORMALIZE)  menu  is  accessed  through  the  keystroke 


HHTH  HEnU 

1.  VECTOR..  1 

a.MflTRIK.. 

3.  LIST.. 
H.HYPEREOLIC. 
5.REHL.. 
S.EASE.. 

1    1  1 

ICAnCL 

OK 

HATRIX  HERU 

l.HflKE..  1 

a.noRHALiaE.. 

3. FACTORS.. 
H.COL.. 
5.R0H.. 
S.LS4 

1         1         1  ICfinCL 

OH 

This  menu  contains  the  following  functions: 


HATRIH  nORH  HERU 

3.RnRH 

H.CnRH 

5.SRAD 

S.CORD 

1         1         1  ICAnCL 

OH 

HATRIH  RORH  HERU 

G.CORD 

7.RARH 

S.DET 

3. TRACE 

10.TRAR 

11. HATRIH..  1 

1         1         1  ICARCL 

OH 
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These  functions  are  described  next.  Because  many  of  these  functions  use 
concepts  of  matrix  theory,  such  as  singular  values,  rank,  etc.,  we  will  include 
short  descriptions  of  these  concepts  intermingled  with  the  description  of 
functions. 

Function  ABS 

Function  ABS  calculates  what  is  known  as  the  Frobenius  norm  of  a  matrix.  For 
a  matrix  A  =  [oij]  ^x„,  the  Frobenius  norm  of  the  matrix  is  defined  as 


u 


If  the  matrix  under  consideration  in  a  row  vector  or  a  column  vector,  then  the 
Frobenius  norm  ,  |  |  A|  |  p ,  is  simply  the  vector's  magnitude.  Function  ABS  is 
accessible  directly  in  the  keyboard  as  I  *-\  j^^s  . 


Try  the  following  exercises  in  ALG  mode  (using  the  matrices  stored  earlier  for 
matrix  operations): 


IR22I 
IR23I 
IB32I 


■flTe 


:  IB33I 

7.J5 

:  IR33I 

2-J70 

:  IR32I 

■i227 

Function  SNRM 

Function  SNRM  calculates  the  Spectral  NoRM  of  a  matrix,  which  is  defined  as 
the  matrix's  largest  singular  value,  also  known  as  the  Euclidean  norm  of  the 
matrix.    For  example. 


:SHRM(R£2) 
:SHRM(fl32) 

] 

:SHRM(R33) 


3. 

14.7146399549 

) 

14. 1S67419471 
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Singular  value  decomposition 

To  understand  the  operation  of  Function  SNRM,  we  need  to  introduce  the 
concept  of  matrix  decomposition.  Basically,  matrix  decomposition  involves 
the  determination  of  two  or  more  matrices  that,  when  multiplied  in  a  certain 
order  (and,  perhaps,  with  some  matrix  inversion  or  transposition  thrown  in), 
produce  the  original  matrix.  The  Singular  Value  Decomposition  (SVD)  is  such 
that  a  rectangular  matrix  A^,,  is  written  as  A^,,  =  U^x,,  S^xn  V  ^„xn, 

Where  U  and  V  are  orthogonal  matrices,  and  S  is  a  diagonal  matrix.  The 
diagonal  elements  of  S  are  called  the  singular  values  of  A  and  are  usually 
ordered  so  that  s,  >  Si+i,  for  i  =  1 ,  2,      n-1 .  The  columns  [U|]  of  U  and  [V|]  of 
V  are  the  corresponding  singular  vectors.  (Orthogonal  matrices  are  such  that 
U-      =  I.  A  diagonal  matrix  has  non-zero  elements  only  along  its  main 
diagonal). 

The  rank  of  a  matrix  can  be  determined  from  its  SVD  by  counting  the  number 
of  non-singular  values.  Examples  of  SVD  will  be  presented  in  a  subsequent 
section. 


Functions  RNRM  and  CNRM 

Function  RNRM  returns  the  Row  NoRM  of  a  matrix,  while  function  CNRM 
returns  the  Column  NoRM  of  a  matrix.  Examples, 


:RHRM(R22) 

8 

:CHRM(R22) 

8 

:RHRM(R33) 

 21 

CnRH  1  £RHD  1  CORD 

21 

:CHRM(R33) 

20 

:RHRM(R23) 

19 

:CHRM(R23) 

  10 

HR£  1  ^nRH  1  RRRH  1  CRRH 

£RAD  1  CORD 

Row  norm  and  column  norm  of  a  matrix 

The  row  norm  of  a  matrix  is  calculated  by  taking  the  sums  of  the  absolute 
values  of  all  elements  in  each  row,  and  then,  selecting  the  maximum  of  these 
sums.  The  column  norm  of  a  matrix  is  calculated  by  taking  the  sums  of  the 
absolute  values  of  all  elements  in  each  column,  and  then,  selecting  the 
maximum  of  these  sums. 
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Function  SRAD 

Function  SRAD  determines  the  Spectral  RADius  of  a  matrix,  defined  as  tfie 
largest  of  the  absolute  values  of  its  eigenvalues.    For  example, 


SRRD(R£2) 
SRflD(fl33) 
SRRD(B22) 


S. 

S.S339 1257969 

) 

15.5156097709 


Definition  of  eigenvalues  and  eigenvectors  of  a  matrix 

The  eigenvalues  of  a  square  matrix  result  from  the  matrix  equation  A  x  =  X  x. 
The  values  of  X  that  satisfy  the  equation  are  knov/n  as  the  eigenvalues  of  the 
matrix  A.  The  values  of  x  that  result  from  the  equation  for  each  value  of  I  are 
known  as  the  eigenvectors  of  the  matrix.    Further  details  on  calculating 
eigenvalues  and  eigenvectors  are  presented  later  in  the  chapter. 


Function  COND 

Function  COND  determines  the  condition  number  of  a  matrix.  Examples, 


C0HD(R22) 
C0HD(B33) 
C0HD(R33r 


9.SS617SS6179 

) 

6.7S714S5943S 


Condition  number  of  a  matrix 

The  condition  number  of  a  square  non-singular  matrix  is  defined  as  the 
product  of  the  matrix  norm  times  the  norm  of  its  inverse,  i.e., 
cond(A)  =  I  I A I  I  X  I  |  A^  |  | .   We  will  choose  as  the  matrix  norm,  |  |  A  |  | ,  the 
maximum  of  its  row  norm  (RNRM)  and  column  norm  (CNRM),  while  the  norm 
of  the  inverse,  |  |  A^  |  |,  will  be  selected  as  the  minimum  of  its  row  norm  and 
column  norm.  Thus,   |  |A|  |  =  max(RNRM(A),CNRM(A)),  and  = 
min(RNRM(Ai),  CNRMIA^)). 
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The  condition  number  of  a  singular  matrix  is  infinity.  The  condition  number  of 
a  non-singular  matrix  is  a  measure  of  how  close  the  matrix  is  to  being 
singular.  The  larger  the  value  of  the  condition  number,  the  closer  it  is  to 
singularity.    (A  singular  matrix  is  one  for  which  the  inverse  does  not  exist). 

Try  the  following  exercise  for  matrix  condition  number  on  matrix  A33.  The 
condition  number  is  COND(A33) ,  row  norm,  and  column  norm  for  A33  are 
shown  to  the  left.     The  corresponding  numbers  for  the  inverse  matrix, 
INV{A33),  are  shown  to  the  right: 


:C0HD(R33) 

6. 

7S714S59438 

:RHRM(R33) 

21. 

:CHRM(R33) 

 20. 

2^ 

COHD(IHV(fl335) 

6.7S714S59437 
RHRM(IHV(fl335) 

.261044176707 
CHRM(IHV(fl335) 
,  .339357429719 


HHD    RHRK   RRRH  R£D 


Since  RNRM(A33)  >  CNRM(A33),  then  we  take  j  j  A33  j  |  =  RNRM(A33)  = 
21.  Also,  since  CNRM(INV(A33))  <  RNRM(INV(A33)),  then  we  take 
I  |INV(A33)|  I  =  CNRM(INV(A33))  =  0.261044...  Thus,  the  condition 
number  is  also  calculated  as  CNRM(A33)*CNRM(INV(A33))  =  COND(A33) 
=  6.7871485... 


Function  RANK 

Function  RANK  determines  the  rank  of  a  square  matrix.  Try  the  following 
examples: 


:RflHK(R22) 

2 

:RRHK(E22) 

2 

The  rank  of  a  matrix 

The  rank  of  a  square  matrix  is  the  maximum  number  of  linearly  independent 
rows  or  columns  that  the  matrix  contains.  Suppose  that  you  write  a  square 
matrix  A^xn  as  A  =  [Ci  €2  ...  ej,  where  Cj  (i  =  1 ,  2,      n)  are  vectors 
representing  the  columns  of  the  matrix  A,  then,  if  any  of  those  columns,  say  c^, 
can  be  written  as      =       ^<^y  '^j^ 
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where  the  values  dj  are  constant,  we  say  that  ei<  is  linearly  dependent  on  the 
columns  included  in  the  summation.  (Notice  that  the  values  of  j  include  any 
value  in  the  set  {1 ,  2,      n},  in  any  combination,  as  long  as  j^^k.)  If  the 
expression  shown  above  cannot  be  written  for  any  of  the  column  vectors  then 
we  say  that  all  the  columns  are  linearly  independent.   A  similar  definition  for 
the  linear  independence  of  rows  can  be  developed  by  writing  the  matrix  as  a 
column  of  row  vectors.     Thus,  if  we  find  that  ranl<(A)  =  n,  then  the  matrix  has 
an  inverse  and  it  is  a  non-singular  matrix.  If,  on  the  other  hand,  rank{A)  <  n, 
then  the  matrix  is  singular  and  no  inverse  exist. 


For  example,  try  finding  the  rank  for  the  matrix: 


2  31 

li 

4  6 

-2  iJ 

RflHKtRHSd)) 


You  will  find  that  the  rank  is  2.  That  is  because  the  second  row  [2,4,6]  is 
equal  to  the  first  row  [1,2,3]  multiplied  by  2,  thus,  row  two  is  linearly 
dependent  of  row  1  and  the  maximum  number  of  linearly  independent  rows  is 
2.  You  can  check  that  the  maximum  number  of  linearly  independent  columns 
is  3.  The  rank  being  the  maximum  number  of  linearly  independent  rows  or 
columns  becomes  2  for  this  case. 

Function  DET 

Function  DET  calculates  the  determinant  of  a  square  matrix.  For  example, 


DET(B33) 
DET(R33) 


-246 
-498 


DET(B22) 
DET(R22) 


-8 
-16 
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The  determinant  of  a  matrix 

The  determinant  of  a  2x2  and  or  a  3x3  matrix  are  represented  by  the  same 
arrangement  of  elements  of  the  matrices,  but  enclosed  between  vertical  lines, 
i.e.. 


«11 

«12 

«13 

'^22 

^^23 

«31 

'^32 

«33 

A  2x2  determinant  is  calculated  by  multiplying  the  elements  in  its  diagonal 
and  adding  those  products  accompanied  by  the  positive  or  negative  sign  as 
indicated  in  the  diagram  shown  below. 


/ 

^11  ^12 


^21  ^22 


e 


© 


The  2x2  determinant  is,  therefore. 


A  3x3  determinant  is  calculated  by  augmenting  the  determinant,  an  operation 
that  consists  on  copying  the  first  two  columns  of  the  determinant,  and  placing 
them  to  the  right  of  column  3,  as  shown  in  the  diagram  below.  The  diagram 
also  shows  the  elements  to  be  multiplied  with  the  corresponding  sign  to  attach 
to  their  product,  in  a  similar  fashion  as  done  earlier  for  a  2x2  determinant. 
After  multiplication  the  results  are  added  together  to  obtain  the  determinant. 
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*11   *12  *13 


1  ' 


*22  ^23 


^31  *32  *33 

t/    ^    ^  ^ 

e  e  e 


*11  ^12' 


21  22 

X  %  \ 


*31  ^3^ 

©     ©  © 


For  square  matrices  of  higher  order  determinants  can  be  calculated  by  using 
smaller  order  determinant  called  cofactors.  The  general  idea  is  to  "expand"  a 
determinant  of  a  nxn  matrix  (also  referred  to  as  a  nxn  determinant)  into  a  sum 
of  the  cofactors,  which  are  (n-1  )x(n-l )  determinants,  multiplied  by  the  elements 
of  a  single  row  or  column,  with  alternating  positive  and  negative  signs.  This 
"expansion"  is  then  carried  to  the  next  (lower)  level,  with  cofactors  of  order  (n- 
2)x(n-2),  and  so  on,  until  we  are  left  only  with  a  long  sum  of  2x2 
determinants.  The  2x2  determinants  are  then  calculated  through  the  method 
shown  above. 


The  method  of  calculating  a  determinant  by  cofactor  expansion  is  very 
inefficient  in  the  sense  that  it  involves  a  number  of  operations  that  grows  very 
fast  as  the  size  of  the  determinant  increases.   A  more  efficient  method,  and 
the  one  preferred  in  numerical  applications,  is  to  use  a  result  from  Gaussian 
elimination.  The  method  of  Gaussian  elimination  is  used  to  solve  systems  of 
linear  equations.  Details  of  this  method  are  presented  in  a  later  part  of  this 
chapter. 


To  refer  to  the  determinant  of  a  matrix  A,  we  write  det(A).  A  singular  matrix 
has  a  determinant  equal  to  zero. 


Function  TRACE 

Function  TRACE  calculates  the  trace  of  square  matrix,  defined  as  the  sum  of 
the  elements  in  its  main  diagonal,  or 


n 

?r(A)  =  2]a„. 

Examples: 
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TRRCE(R22) 
TRRCE(E22) 


-6 
15 


TRRCE(fl33) 
TRRCE(E33) 


4 
-7 


Function  TRAN 

Function  TRAN  returns  the  transpose  of  a  real  or  the  conjugate  transpose  of  a 
complex  matrix.  TRAN  is  equivalent  to  TRN.  The  operation  of  function  TRN 
was  presented  in  Chapter  10. 

Additional  matrix  operations  (The  matrix  OPER  menu) 

The  matrix  OPER  (OPERATIONS)  is  available  through  the  keystroke  sequence 
[j^MATRas  (system  flag  1  1 7  set  to  CHOOSE  boxes): 


The  OPERATIONS  menu  includes  the 


HHTRICEf  HEnU 

l.CREHTE..  1 

a.OPERflTIOnS.. 

^.FACTORIZHTIOn..  1 
H. QUADRATIC  FORM..  1 
S.LIREAR  £Y£TEH£..  H 
S.LinEAR  APPL..  U 

1         1         1  ICHnCLl 

OK 

ollov/ing  functions: 


MATRIX  OPERATIOn^  MERU 

MATRIK  OPERATIOR^  MERU 

7.HADAMARD  [ 

S.LSt 

?.AKM 

3.  MAD 

H.CnRM 

lO.RARK 

5. CORD 

ll.RRRM 

S.DET 

12.R;D  II 

1         1         1  ICAnCL 

OK 

1         1         1  ICARCL 

OK 

MATRIK  OPERATIORS  MERU 


13. SIZE 
IH.^RRM 
IS.^RAD 
IE. TRACE 
1?.TRAR 


IS. MATRICES.. 


Functions  ABS,  CNRM,  COND,  DET,  RANK,  RNRM,  SNRM,  TRACE,  and 
TRAN  are  also  found  in  the  MTH/MATRIX/NORM  menu  (the  subject  of  the 
previous  section).  Function  SIZE  v/as  presented  in  Chapter  1 0.  Function 
HADAMARD  was  presented  earlier  in  the  context  of  matrix  multiplication. 
Functions  LSQ  ,  MAD  and  RSD  are  related  to  the  solution  of  systems  of  linear 
equations  and  will  be  presented  in  a  subsequent  section  in  this  Chapter.  In 
this  section  we'll  discuss  only  functions  AXL  and  AXM 
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Function  AXL 

Function  AXL  converts  an  array  (matrix)  into  a  list,  and  vice  versa.  For 
examples^  


B32 


RXL(B32) 


0  3 
5  -61 
-4  -SJ 


E33 


RXL(B33) 


-4  1  71 

-4  -5  7 
-7  6  2\ 


m  3>  {5  -6>  {-4  -3>}     t{-4  1  7>  {-4  -5  7>  {-7  6  2> 


Note:  the  latter  operation  is  similar  to  that  of  the  program  CRMR  presented  in 
Chapter  10. 


Function  AXM 

Function  AXM  converts  an  array  containing  integer  or  fraction  elements  into  its 
corresponding  decimal,  or  approximate,  form.  For  example. 


-19 

-4 

£5 

£49 

249 

249 

-1 

26 

-33 

249 

249 

249 

47 

23 

43 

1 493 

mwm 

493 
11^ 

493. 

47    23  43 


49S  49S  49S 
RXMtRHSd)) 

-7. 6305220SS35E-2  -1 .  ^ 
-4.01606425703E-3  .* 
9.43775100402E-2  4.6 


Function  LCXM 

Function  LCXM  can  be  used  to  generate  matrices  such  that  the  element  aij  is  a 
function  of  i  and  j.  The  input  to  this  function  consists  of  two  integers,  n  and  m, 
representing  the  number  of  rows  and  columns  of  the  matrix  to  be  generated, 
and  a  program  that  takes  i  and  j  as  input.   The  numbers  n,  m,  and  the 
program  occupy  stack  levels  3,  2,  and  1 ,  respectively.  Function  LCXM  is 
accessible  through  the  command  catalog  I  r»  J  cat  . 

For  example,  to  generate  a  2'3  matrix  whose  elements  are  given  by  = 
(i+j)^,  first,  store  the  following  program  into  variable  PI  in  RPN  mode.   This  is 
the  way  that  the  RPN  stack  looks  before  pressing  [sto)  . 


3 1 

2:  -s      i  j  -s  '  (i+j>-^2 

'  EVRL  s-  s- 
l!  'PI 
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The  implementation  of  function  LCXM  for  tfiis  cose  requires  you  to  enter: 

The  following  figure  shows  the  RPN  stack  before  and  after  applying  function 
LCXM: 


3:  2. 

l:  -s;  ■>  i  j  -s;  '  (i+j>-^2! 
'  EVRL  »■  »■   , 


3: 

2: 

\4.  9. 

16.1 

13.  16. 

25.  J 

In  ALG  mode,  this  example  con  be  obtained  by  using 


The  program  PI  must  still  have  been  created  and  stored  in  RPN  mode. 

Solution  of  linear  systems 

A  system  of  n  linear  equations  in  m  variables  can  be  written  as 


an-Xi 


+  a,2-X2   +  ai3-X3   +  ...+  a 


+  ai 


-xi    +a22-X2   +a23-X3   +  •  •  •+  a2,,,.i  "X  m-1  +a2,m-x, 

031 -Xi     +a32-X2     +a33-X3     +...+   03,^.1  "X  m-1  +03^X1 


=  bi, 
=  b2, 

=  b3, 


a„.i,rxi  +  a„.i,2-X2  +  a„.i,3-X3  +  ...+  a,.i,^.i-x  „.i  +  a,.i,„-x  ^  =  b„.i, 

Oni-Xi  +    an2-X2    +    an3-X3     +  ...+     an  „,.TX  ^.1    +    On  i^-X  „    =  bp. 


This  system  of  linear  equations  can  be  written  as  a  matrix  equation,  A^^m'^mx] 
=  bnxi,  if  we  define  the  following  matrix  and  vectors: 


«12  • 

~w 

A  = 

^22 

•  «2«, 

/ 

X  = 

X2 

1 

h  = 

««2  • 

^nm  _ 

mxl 
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Using  the  numerical  solver  for  linear  systems 

There  are  many  ways  to  solve  a  system  of  linear  equations  with  the  calculator. 
One  possibility  is  through  the  numerical  solver  [  jnimslv  .  From  the  numerical 
solver  screen,  shown  below  (left),  select  the  option  4.  Solve  I'm  sys..,  and 


press  IE!: 


II.  The  following  input  form  wi  I  be  provide  (right): 


S.MSLV 


EDIT  CHOO£ 


To  solve  the  linear  system  A  x  =  b,  enter  the  matrix  A,  in  the  format  [[  On, 

ai2,  ■■■  ]/  ■■■  [■■■■]]  in  the  A;  field.  Also,  enter  the  vector  b  in  the  B:  field. 
When  the  X:  field  is  highlighted,  press  [SOLVE].  If  a  solution  is  available,  the 
solution  vector  x  will  be  shown  in  the  X:  field.  The  solution  is  also  copied  to 
stack  level  1 .  Some  examples  follow. 


A  square  system 

The  system  of  linear  equations 

2xi  +  3x2  -5x3  =  1  3, 
Xi  -  3x2  +  8x3  =  -1 3, 
2xi  -  2x2  +  ^^^3  =  -6, 


can  be  written  as  the  matrix  equation  A-x  =  b,  if 


2 

3 

-5 

Xi 

13 

A  = 

1 

-3 

8 

,    x  = 

Xj 

,    and  b 

-13 

2 

-2 

4 

X3  _ 

-6 

This  system  has  the  same  number  of  equations  as  of  unknowns,  and  will  be 
referred  to  as  a  square  system.  In  general,  there  should  be  a  unique  solution 
to  the  system.  The  solution  will  be  the  point  of  intersection  of  the  three  planes 
in  the  coordinate  system  (x,,  X2,  X3)  represented  by  the  three  equations. 
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To  enter  matrix  A  you  can  activate  the  Matrix  Writer  while  the  A:  field  is 
selected.  The  following  screen  shows  the  Matrix  Writer  used  for  entering 
matrix  A,  as  well  as  the  input  form  for  the  numerical  solver  after  entering 
matrix  A  (press  [inter)  In  the  Matrix  Writer): 


1. 

2. 


-3. 

-2. 


S. 
4. 


EDIT   VEC  ■  +4IID  HIDh 


Enttr  cosfficisntj  Matrix  fl 


EDIT  CHDDS 


Press       to  select  the  B:  field.  The  vector  b  can  be  entered  as  a  row  vector 
with  a  single  set  of  brackets,  i.e.,  L  13?  -13!         HL9  . 
After  entering  matrix  A  and  vector  b,  and  with  the  X:  field  highlighted,  we  can 
press  kESBjI  to  attempt  a  solution  to  this  system  of  equations: 


SOLVE  SYSTEM  fl-K=D 

[[2. ,3. ,-5.]  [1.,- 
C13. ,-13. ,6. ] 


Enttr  jolutionj  or  pnii  SOLVE 


EDIT  CHOOS 


A  solution  was  found  as  shown  next. 


SOLVE  SYSTEM  fl-K=D 

[[2. ,3. ,-5.]  [1.,-.. 
[13. ,-13. ,-6. ] 


Entif  f*luti*n5  or  pr«ff  SOLVE 


EDIT  CHOOS 


To  see  the  solution  in  the  stack  press  (Ster]  .    The  solution  is  x  =  [1 ,2,-1  ]. 


SolutionsiEl.  2.  -1.1 


To  check  that  the  solution  is  correct,  enter  the  matrix  A  and  multiply  times  this 
solution  vector  (example  in  algebraic  mode): 
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Solutions:[l.  2.  -1.] 


Under-determined  system 

The  system  of  linear  equations 


2xi  +  3x2  -5x3  =  -10, 
Xi  -  3x2  +  8x3  =  85, 


can  be  written  as  the  matrix  equation  A  x  =  b,  if 


X, 


2  3 


-5 


10 


A  = 


X  = 


and    b  = 


1    -3  8 


85 


This  system  has  more  unknowns  than  equations,  therefore,  it  is  not  uniquely 
determined.  We  con  visualize  the  meaning  of  this  statement  by  realizing  that 
each  of  the  linear  equations  represents  a  plane  in  the  three-dimensional 
Cartesian  coordinate  system  (x,,  X2,  X3).  The  solution  to  the  system  of 
equations  shown  above  will  be  the  intersection  of  two  planes  in  space.  We 
know,  however,  that  the  intersection  of  two  (non-parallel)  planes  is  a  straight 
line,  and  not  a  single  point.  Therefore,  there  is  more  than  one  point  that 
satisfy  the  system.  In  that  sense,  the  system  is  not  uniquely  determined. 

Let's  use  the  numerical  solver  to  attempt  a  solution  to  this  system  of  equations: 
{jfjMMs&  <^<:^^  lllal  .    Enter  matrix  A  and  vector  b  as  illustrated  in  the 
previous  example,  and  press  eSEEEj  when  the  X:  field  is  highlighted: 
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SOLVE  SYSTEM  fl-K=E 
fl: [[2. ,3. ,-5. ]  [1. 

t-  [-10.  ,35.  ] 


[15.3731343234,2.4.. 


Enttr  jolutionj  or  pnii  SOLVE 


EDIT  CHOOS 


To  see  the  details  of  the  solution  vector,  if  needed,  press  the  EiSm  button. 
This  will  activate  the  Matrix  Writer.  Within  this  environment,  use  the  right- 
and  left-arrow  keys  to  move  about  the  vector,  e.g.. 


1-3:  9.62636567164 


EDIT   VEC  ■  +4IID   HID-f  GO-t"  G0+ 


Thus,  the  solution  is  x  =  [15.373,  2.4626,  9.6268]. 

To  return  to  the  numerical  solver  environment,  press  [ihtek)  . 

The  procedure  that  we  describe  next  can  be  used  to  copy  the  matrix  A  and 
the  solution  vector  X  into  the  stack.  To  check  that  the  solution  is  correct,  try 
the  following: 


Press  to  highlight  the  A:  field. 

Press  LaatJ  itii. i.. {enter]  ^  to  copy  matrix  A  onto  the  stack. 

Press  SESSB  to  return  to  the  numerical  solver  environment. 

Press  IIIl 111  [enter)  ,  to  copy  solution  vector  X  onto  the  stack. 

Press  to  return  to  the  numerical  solver  environment. 

Press  [enter]  to  return  to  the  stack. 


In  ALG  mode,  the  stack  will  now  look  like  this: 
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So 1 ut  i  ons : [ 1 5^  373 1 3^3^  j 

Let's  store  the  latest  result  in  a  variable  X,  and  the  matrix  into  variable  A,  as 
follows: 

Press  Isto*][alpha)(x\  [enter]  to  store  the  solution  vector  into  variable  X 
Press  L4J  [_4J        to  clear  three  levels  of  the  stack 
Press  lsTc»}{ALPHA)(A]lENTER}  to  store  the  matrix  into  variable  A 

Nov/,  let's  verify  the  solution  by  using:  KIHIl  x  J  SEIS  [enter)  ,  which  results  in 
(press  ^  to  see  the  vector  elements):  [-9.99999999999  85.  ],  close  enough 
to  the  original  vector  b  =  [-10  85]. 

Try  also  this,  iESSCXD  [15,  18]        Cg^Jzwwl^,  i.e.. 


:fl{l5^10] 

-3S.  255. 1 

3  3 
:-*HUM(flHS(l)) 

[-10.  35.] 

This  result  indicates  that  x  =  [1 5,1 0/3,1 0]  is  also  a  solution  to  the  system, 
confirming  our  observation  that  a  system  with  more  unknowns  than  equations 
is  not  uniquely  determined  (under-determined). 

How  does  the  calculator  came  up  with  the  solution  x  =  [15.37...  2.46... 
9.62...]  shown  earlier?  Actually,  the  calculator  minimizes  the  distance  from  a 
point,  which  will  constitute  the  solution,  to  each  of  the  planes  represented  by 
the  equations  in  the  linear  system.  The  calculator  uses  a  least-square  method, 
i.e.,  minimizes  the  sum  of  the  squares  of  those  distances  or  errors. 

Over-determined  system 

The  system  of  linear  equations 

Xi  +  3x2  =  1 5, 
2x,  -  5x2  =  5, 
-x,  +  X2  =  22, 
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can  be  written  as  the  matrix  equation  A-x  =  b,  if 

,    and  b 


A  = 


1  3 

2  -5 
-1  1 


X  = 


X, 


15 

5 

22 


This  system  has  more  equations  than  unknowns  (an  over-determined  system). 
The  system  does  not  have  a  single  solution.     Each  of  the  linear  equations  in 
the  system  presented  above  represents  a  straight  line  in  a  two-dimensional 
Cartesian  coordinate  system  (x,,  X2).  Unless  two  of  the  three  equations  in  the 
system  represent  the  same  equation,  the  three  lines  will  have  more  than  one 
intersection  points.  For  that  reason,  the  solution  is  not  unique.  Some 
numerical  algorithms  can  be  used  to  force  a  solution  to  the  system  by 
minimizing  the  distance  from  the  presumptive  solution  point  to  each  of  the 
lines  in  the  system.    Such  is  the  approach  followed  by  the  HP  49  G  numerical 
solver. 

Let's  use  the  numerical  solver  to  attempt  a  solution  to  this  system  of  equations: 
{j^]NUM.sLv_  '^^'^^'^^  lilli  .    Enter  matrix  A  and  vector  b  as  illustrated  in  the 
previous  example,  and  press  y-.'-l'"-  when  the  X:  field  is  highlighted: 


SOLVE  SYSTEM  fl-K=E 
fl: [[1. ,3. ]    [2. ,-5. ] 

C15.  ,5.  ,22.  ] 


C3. 02054794521,  I.S.. 


Enter  jolutionj  or  prejj  SOLVE 


EDIT  CHOOS 


To  see  the  details  of  the  solution  vector,  if  needed,  press  the  EuEli  button. 
This  will  activate  the  Matrix  Writer.  Within  this  environment,  use  the  right- 
and  left-arrow  keys  to  move  about  the  vector,  e.g.. 


EDIT   VEC  ■  +4IID   HID-» M]0-»i  G0+ 


1-2:  1.S9041095S9 


EDIT   VEC  ■  +4IID   HID-» M]0-»i  G0+ 
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Press  (mS]  to  return  to  the  numerical  solver  environment.  To  check  that  the 
solution  is  correct,  try  the  following: 


•  Press  (^(^ ,  to  highlight  the  A:  field. 

•  Press  [nxt]  mS^{ENm}^  to  copy  matrix  A  onto  the  stack. 

•  Press  SESSS  to  return  to  the  numerical  solver  environment. 

•  Press  13111311  lw«J ,  to  copy  solution  vector  X  onto  the  stack. 

•  Press  ~  ■"!■■  to  return  to  the  numerical  solver  environment. 

•  Press  [tAfT-fflj  to  return  to  the  stack. 

In  ALG  mode,  the  stack  v/ill  now  look  like  this: 


Let's  store  the  latest  result  in  a  variable  X,  and  the  matrix  into  variable  A,  as 
follov/s: 

Press  |W] (^i™) (3  (ms)  to  store  the  solution  vector  into  variable  X 
Press  [  4  J  L    J  I  4  J  to  clear  three  levels  of  the  stack 
Press  lsTc»}[ALPHA){A]iENTEi<}  to  store  the  matrix  into  variable  A 

Nov/,  let's  verify  the  solution  by  using:  iliilli L21J  iEWII  [wraj,  v^hich  results  in 
the  vector  [8.6917...  -3.4109...  -1.1301...],  v^hich  is  not  equal  to  [15  5  22], 
the  original  vector  b.  The  "solution"  is  simply  the  point  that  is  closest  to  the 
three  lines  represented  by  the  three  equations  in  the  system,  and  not  an  exact 


Least-square  solution  (function  LSQ) 

The  LSQ  function  returns  the  minimum-norm  least-square  solution  of  a  linear 
system  Ax  =  b,  according  to  the  follov/ing  criteria: 


Solut  ions: [3. 02054794^> 


solution. 
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•  If  A  is  a  square  matrix  and  A  is  non-singular  (i.e.,  it's  inverse  matrix 
exist,  or  its  determinant  is  non-zero),  LSQ  returns  the  exact  solution  to 
the  linear  system. 

•  If  A  has  less  than  full  row  rank  (underdetermined  system  of  equations), 
LSQ  returns  the  solution  with  the  minimum  Euclidean  length  out  of  an 
infinity  number  of  solutions. 

•  If  A  has  less  than  full  column  rank  (over-determined  system  of 
equations),  LSQ  returns  the  "solution"  with  the  minimum  residual  value 
e  =  A  x  -  b.  The  system  of  equations  may  not  have  a  solution, 
therefore,  the  value  returned  is  not  a  real  solution  to  the  system,  just 
the  one  with  the  smallest  residual. 


Function  LSQ  takes  as  input  vector  b  and  matrix  A,  in  that  order.  Function 
LSQ  can  be  found  in  Function  catalog  ([    J  cat_  ).  Next,  we  use  function  LSQ 
to  repeat  the  solutions  found  earlier  with  the  numerical  solver: 


Square  system 

Consider  the  system 


wi 


ith 


2xi  -I-  3x2  -5x3  =  1 3, 
Xi  -  3x2  -I-  8x3  =  -1 3, 
2xi  -  2x2  +  4x3  =  -6, 


A  = 


2 

3 

-5" 

"  13 

1 

-3 

8 

,    x  = 

X2 

,    and    b  = 

-13 

2 

-2 

4 

3. 

-6 

The  solution  using  LSQ  is  shown  next: 
12  -2 


-2  4  J 


[13  -13  -6] 


2  3  -51 

1  -3  3 
2-2  4 


[13  -13  -6] 


1 1  -a  y  I 

I2-2  4  J 


:[13  -13  -6] 

[13  -13  -6] 
LSQ(RHS(1),RHS(2)) 

[1.  2.  -U 


+^KIP  SKIP-H  H)EL   DEL-f  DEL  L  inS  ■ 
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Under-determined  system 

Consider  the  system 


2xi  +  3x2  -5x3  =  -10, 
Xi  -  3x2  +  8x3  =  85, 


with 


A  = 


2  3 
1  -3 


X  = 


and   b  = 


-10 
85 


The  solution  using  LSQ  is  shown  next: 


AZ  3  -51 

■ll  -3  3  J 

\2  3 

-11 

ll  -3 

:[-10  S5] 

[-10 

35] 

DEL-»|DEL  L| 

ins  ■ 

11  -y  y  J 


[-10  35] 


[2  3  -5j 
ll  -3  3  J 


LSQ(flHS(l),flHS(2)) 


[-10  35] 


Over-determined  system 

Consider  the  system 


with 


X,  +  3x2  =  1 5, 
2xi  -  5x2  =  5, 
-Xi  +  X2  =  22, 


A  = 


1 

2 


3 

-5 
1 


X  = 


X, 


and  b 


15 
5 

22 


The  solution  using  LSQ  is  shown  next: 


[15  5  22] 

[15  5  22] 
LSQ(RHS(l),flHS(25) 
t3 . 0205479452 1 1 . 3904 1 H 


t^KIP  SKIPH  H)EL   DEL-f  DEL  L  inS  i 


*^KIF|SKIF-H  H)EL  I  DEL->|DEL  L|  inS  ■! 
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Compare  these  three  solutions  with  the  ones  calculated  with  the  numerical 
solver. 

Solution  with  the  inverse  matrix 

The  solution  to  the  system  A  x  =  b,  where  A  is  a  square  matrix  is  x  =  A^-  b. 
This  results  from  multiplying  the  first  equation  by  A\  i.e.,  A^-A  x  =  A^-b.  By 
definition,  A^-A  =  I,  thus  we  write  l-x  =  A^-b.  Also,  l-x  =  x,  thus,  we  have, 
x  =  A  b. 

For  the  example  used  earlier,  namely, 

2xi  +  3x2  -5x3  =  1  3, 

Xi  -  3x2  +  8x3  =  -1 3, 

2xi  -  2x2  +  4x3  =  -6, 
we  can  find  the  solution  in  the  calculator  as  follows: 

[2  3  -51 
1  -3  S  I 
2-241 

-6]  ] 
C13  -13  -61 


3  I 

4  J 

:[13  -13  -61 

[13  -13  -61 
:  IHV(RHS(2))flHS(l) 

[1  2 -11 

which  is  the  same  result  found  earlier. 
Solution  by  'division"  of  matrices 

While  the  operation  of  division  is  not  defined  for  matrices,  we  can  use  the 
calculator's  I  -n  J  key  to  "divide"  vector  b  by  matrix  A  to  solve  for  x  in  the 
matrix  equation  A-x  =  b.  This  is  an  arbitrary  extension  of  the  algebraic 
division  operation  to  matrices,  i.e.,  from  A  x  =  b,  we  dare  to  write  x  =  b/A 
(Mathematicians  would  cringe  if  they  see  this!)  This,  of  course  is  interpreted  as 
(l/A)-b  =  A^  b,  which  is  the  same  as  using  the  inverse  of  A  as  in  the 
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previous  section.  The  procedure  for  the  case  of  "dividing"  b  by  A  is 
illustrated  belov/  for  the  case 


2xi  +  3x2  -5x3  =  1  3, 


3xo  +  8> 


-13, 


2xi  -  2x2  +  4x3  =  -6, 
The  procedure  is  shown  in  the  following  screen  shots: 


[13  -13  -62 

RHStl) 
flHS(2) 


[2-2  4J 
[13  -13  -61 


[1  2  -11 


The  same  solution  as  found  above  with  the  inverse  matrix. 

Solving  multiple  set  of  equations  with  the  same  coefficient  matrix 

Suppose  that  you  want  to  solve  the  following  three  sets  of  equations: 
X  +2Y+3Z  =14,     2X  +4Y+6Z  =  9,      2X  +4Y+6Z  =  -2, 
3X  ■2Y+  Z  =  2,    3X  -2Y+  Z  =  -5,      3X  ■2Y+  Z  =  2, 
4X  +2Y  -Z  =  5,  4X  +2Y  -Z  =  1 9,      4X  +2Y  -Z  =  1 2. 

We  can  write  the  three  systems  of  equations  as  a  single  matrix  equation:  A-X 

=  B,  where 


"1 

2 

3  " 

^(1) 

^(2) 

^(3) 

A  = 

3 

-2 

1 

X  = 

Y 

^(2) 

Y 

4 

2 

-1 

7 

7 

-^(2) 

7 

^(3) 

"14 

9 

B  = 

2 

-5 

2 

5 

19 

12 
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The  sub-indices  in  the  variable  names  X,  Y,  and  Z,  determine  to  which 
equation  system  they  refer  to.  To  solve  this  expanded  system  we  use  the 
following  procedure,  in  RPN  mode, 

I.  L  .L  'i-  II  y  II  -     J  (  1.     1  —.J  <  ilJ  1  I.  ._i  1  1  :?  ?  i     J  J  (flWE?) 

[[  1,2,  3:1,  [3,-2,  1:1,1:4,2,-1:1] 
The  result  of  this  operation  is: 


1 

2 

2 

x  = 

2 

5 

1 

3 

-1 

-2 

Gaussian  and  Gauss-Jordan  elimination 

Gaussian  elimination  is  a  procedure  by  which  the  square  matrix  of  coefficients 
belonging  to  a  system  of  n  linear  equations  in  n  unknowns  is  reduced  to  an 
upper-triangular  matrix  (echelon  form)  through  a  series  of  row  operations. 
This  procedure  is  known  as  forward  elimination.  The  reduction  of  the 
coefficient  matrix  to  an  upper-triangular  form  allows  for  the  solution  of  all  n 
unknowns,  utilizing  only  one  equation  at  a  time,  in  a  procedure  known  as 
backward  substitution. 

Example  of  Gaussian  elimination  using  equations 

To  illustrate  the  Gaussian  elimination  procedure  we  will  use  the  following 
system  of  3  equations  in  3  unknowns: 

2X  +4Y+6Z=  14, 

3X  -2Y+  Z  =  -3, 

4X+2Y  -Z  =  -4. 

We  can  store  these  equations  in  the  calculator  in  variables  El,  E2,  and  E3, 
respectively,  as  shown  below.  For  backup  purposes,  a  list  containing  the 
three  equations  was  also  created  and  stored  into  variable  EQS.  This  way,  if  a 
mistake  is  made,  the  equations  will  still  be  available  to  the  user. 
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2.  X+4.Y+6.Z=14frEl 

3.  X-2.Y+Z=-3frE2 

3.X-(2.Y-Z)=-3 

4.  X+2.Y-Z=-4frE3 

4'X+2'Y-Z=-4 


El 

E2 
E3 


2'X+4'Y+6'Z=14 
3.X-(2.Y-Z)=-3 
4'X+2'Y-Z=-4 


To  start  the  process  of  forward  elimination,  we  divide  tfie  first  equation  (El )  by 
2,  and  store  it  in  El,  and  show  the  three  equations  again  to  produce: 


E2 
E3 


X+2'Y+3'Z-7 
3.X-(2.Y-Z)=-3 
4'X+2'Y-Z=-4 


Next,  we  replace  the  second  equation  E2  by  (equation  2  -  Sxequation  1, 
El-3xE2),  and  the  third  by  (equation  3  -  4xequation  1),  to  get 


E2-3€lfrE2 
E3-4€lfrE3 


-(S.Y+S.Z-24) 
-(6'Y+13'Z-32) 


El 
E2 
E3 


X+2'Y+3'Z-7 
-(S.Y+S.Z-24) 
-(6'Y+13'Z-32) 


Next,  divide  the  second  equation  by  -8,  to  get 


Y+Z-3 


El 
E2 
E3 


X+2'Y+3'Z-7 
Y+Z-3 
-(6'Y+13'Z-32) 


Next,  replace  the  third  equation,  E3,  with  (equation  3  +  6xequation  2,  i.e., 
E2+6xE3),  to  get  


E3+6€2frE3 


-(7'Z-14) 


El 
E2 
E3 


X+2'Y+3'Z-7 
Y+Z-3 
-(7'Z-14) 


Notice  that  when  we  perform  a  linear  combination  of  equations  the  calculator 
modifies  the  result  to  an  expression  on  the  left-hand  side  of  the  equal  sign,  i.e., 
on  expression  =  0.  Thus,  the  last  set  of  equations  is  interpreted  to  be  the 
following  equivalent  set  of  equations: 

X  +2Y+3Z  =  7, 
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Y+  Z  =  3, 
-7Z  =  -14. 

The  process  of  backward  substitution  in  Gaussian  elimination  consists  in 
finding  tfie  values  of  the  unknowns,  starting  from  the  last  equation  and 
working  upwards.  Thus,  we  solve  for  Z  first: 


E2 
E3 

S0LVE(E3;Z') 


Y+Z-3 
-(7.Z-14) 
Z=2 


E3 

S0LVE(E3;Z') 


SUEST(E2,flHS(l))^E2 


V+Z-3 
-(7'Z-14) 
Z=2 


Y+2-3 


Next,  we  substitute  Z=2  into  equation  2  (E2),  and  solve  E2  for  Y: 


:S0LVE(E3;Z') 
:SUBST(E2,flHS(l))tE2 
:S0LVE(E2;Y') 


-(7.Z-14) 
Z=2 
Y+2-3 
Y=l 


Next,  we  substitute  Z=2  and  Y  =  1  into  El ,  and  solve  El  for  X: 

X+2.1+3.Z-71 


SUBST(E1,Y=1) 

X+2.1+3.Z-7 
SUBST(RHS(1),Z=2) 

X+2.1 +3.2-7 

RHStDfrEl 

X+2. 1+3.2-7 


SUBST(flHSa),Z=2) 

X+2.1 +3.2-71 

RHStDfrEl 

X+2. 1+3.2-71 
SOLVE(flHSaVX') 

X=-l 


The  solution  is,  therefore,  X  =  -1,  Y  =  1,  Z  =  2. 
Example  of  Gaussian  elimination  using  matrices 

The  system  of  equations  used  in  the  example  above  can  be  written  as  a  matrix 
equation  A-x  =  b,  if  we  use: 


(2 

4 

6^ 

'x' 

"14 

A  = 

3 

-2 

1 

,    x  = 

Y 

,   b  = 

-3 

.4 

2 

-I 

Z 

-4 

To  obtain  a  solution  to  the  system  matrix  equation  using  Gaussian  elimination, 
we  first  create  what  is  known  as  the  augmenfed  matrix  corresponding  to  A, 
i.e.. 
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2  4 


6 


A 


aug 


3  - 


2  1 


3 


V 


4  2-1 


-4 


The  matrix  A^^g  is  the  same  as  the  original  matrix  A  with  a  new  row, 
corresponding  to  the  elements  of  the  vector  b,  added  (i.e.,  augmented)  to  the 
right  of  the  rightmost  column  of  A. 

Once  the  augmented  matrix  is  put  together,  we  can  proceed  to  perform  row 
operations  on  it  that  will  reduce  the  original  A  matrix  into  an  upper-triangular 
matrix.  For  this  exercise,  we  will  use  the  RPN  mode  (Imode}[  +i-  jEM),  with 
system  flag  117  set  to  SOFT  menu.  In  your  calculator,  use  the  following 
keystrokes.  First,  enter  the  augmented  matrix,  and  make  an  extra  copy  of  the 
same  in  the  stack  (This  step  is  not  necessary,  except  as  an  insurance  that  you 
have  an  extra  copy  of  the  augmented  matrix  saved  in  case  you  make  a 
mistake  in  the  forward  elimination  procedure  that  we  are  about  to  undertake.): 

L.  L  i:;  J  4  H  b  J  1 4  .J  5  L  d  4  —ii:  5  1  ?       J  ;i  L  4  5    3  "■■  1 ;.  -!■  .J  .1  [enter) (enter) 

Save  augmented  matrix  in  variable  AAUG:  CZIl(d™l(^™)(3(30(Sl(d™l 

With  a  copy  of  the  augmented  matrix  in  the  stack,  press  [jTJmth_  [[EHSI  Q3III 
to  activate  the  ROW  operation  menu.    Next,  perform  the  following  row 
operations  on  your  augmented  matrix. 
Multiply  row  1  by  V2:  C5JCS  CX3  ESi 


Multiply  row  1  by  -3  add  it  to  row  2,  replacing  it:  I  3  Jl  *i-  J    [sfc)  [  /  j 

[SRC  )l  2  J  UiaifJ 

Multiply     row     1     by     -4     add     it     to     row     3,     replacing  it: 
CZD  lEI^^w 

Multiply  row  2  by  -1/8:  CZDC^CEDCTD  lESi 

Multiply  row  2  by  6  add  it  to  row  3,  replacing  it:  CIDC^CTDC^CTD  'SMSi 
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If  you  were  performing  tfiese  operations  by  fiand,  you  would  write  tfie 
following: 


f2 

4 

6 

14] 

^1 

2 

3 

7^ 

A 

mg 

3 

-2 

1 

-3 

3 

-2 

1 

-3 

I4 

2 

1 

2 

-1 

-\ 

2 

3 

7  ^ 

ri 

2 

3 

1 

A  = 

^aug  - 

0 

-8 

-8 

-24 

0 

1 

1 

3 

-6  - 

-13 

-32, 

-6 

-13 

-32J 

2 

3 

7  ] 

A  - 

aug 

0 

1 

1 

3 

.0 

0 

-7 

-14, 

The  symbol  =  ("  is  equivalent  to")  indicates  tfiat  what  follows  is  equivalent  to 
the  previous  matrix  with  some  row  (or  column)  operations  involved. 

The  resulting  matrix  is  upper-triangular,  and  equivalent  to  the  set  of  equations 

X  +2Y+3Z  =  7, 
Y+  Z  =  3, 
-7Z  =  -14, 

which  can  now  be  solved,  one  equation  at  a  time,  by  backward  substitution, 
as  in  the  previous  example. 

Gauss-Jordan  elimination  using  matrices 

Gauss-Jordan  elimination  consists  in  continuing  the  row  operations  in  the 
upper-triangular  matrix  resulting  from  the  forward  elimination  process  until  an 
identity  matrix  results  in  place  of  the  original  A  matrix.  For  example,  for  the 
case  we  just  presented,  we  can  continue  the  row  operations  as  follows: 

Multiply  row  3  by  -1/7:  CZDC^CED  QD  IS^ 

Multiply  row  3  by  -1,  add  it  to  row  2,  replacing  it:   I  /  JL  *i-  J    jspc]  i  3  j 
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Multiply  row  3  by  -3,  add  it  to  row  1,  replacing  it: 
CX)      CED  (X)      CTD  E-SiBI 


Multiply  row  2  by  -2,  add  it  to  row  1,  replacing  it:  mr^C^^mC^fTl 
Writing  this  process  by  hand  will  result  in  the  following  steps: 


'1 

2 

3 

7  ^ 

ri 

2 

3 

7^ 

fl 

2 

3 

7^ 

A  = 

0 

1 

1 

3 

0 

1 

1 

3 

0 

1 

1 

1 

.0 

0 

-7 

-14^ 

.0 

0 

1 

2. 

.0 

0 

1 

2. 

ri  2 

0 

ri 

0 

0 

-1^ 

0  1 

0 

1 

0 

1 

0 

1 

^0  0 

1 

2. 

.0 

0 

1 

2. 

Pivoting 

If  you  look  carefully  at  the  row  operations  in  the  examples  shown  above,  you 
will  notice  that  many  of  those  operations  divide  a  row  by  its  corresponding 
element  in  the  main  diagonal.  This  element  is  called  a  pivot  element,  or 
simply,  a  pivot.  In  many  situations  it  is  possible  that  the  pivot  element 
become  zero,  in  which  case  we  cannot  divide  the  row  by  its  pivot.  Also,  to 
improve  the  numerical  solution  of  a  system  of  equations  using  Gaussian  or 
Gauss-Jordan  elimination,  it  is  recommended  that  the  pivot  be  the  element 
with  the  largest  absolute  value  in  a  given  column.  In  such  cases,  we 
exchange  rows  before  performing  row  operations.  This  exchange  of  rows  is 
called  partial  pivoting.  To  follow  this  recommendation  is  it  often  necessary  to 
exchange  rows  in  the  augmented  matrix  while  performing  a  Gaussian  or 
Gauss-Jordan  elimination. 

While  performing  pivoting  in  a  matrix  elimination  procedure,  you  can 
improve  the  numerical  solution  even  more  by  selecting  as  the  pivot  the  element 
with  the  largest  absolute  value  in  the  column  and  row  of  interest.  This 
operation  may  require  exchanging  not  only  rows,  but  also  columns,  in  some 
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pivoting  operations.  When  row  and  column  exchanges  are  allowed  in 
pivoting,  the  procedure  is  known  as  full  pivofing. 

When  exchanging  rows  and  columns  in  partial  or  full  pivoting,  it  is  necessary 
to  keep  track  of  the  exchanges  because  the  order  of  the  unknowns  in  the 
solution  is  altered  by  those  exchanges.  One  way  to  keep  track  of  column 
exchanges  in  partial  or  full  pivoting  mode,  is  to  create  a  permutation  matrix  P 
=  Inxn/  at  the  beginning  of  the  procedure.  Any  row  or  column  exchange 
required  in  the  augmented  matrix  A^^g  is  also  registered  as  a  row  or  column 
exchange,  respectively,  in  the  permutation  matrix.  When  the  solution  is 
achieved,  then,  we  multiply  the  permutation  matrix  by  the  unknown  vector  x 
to  obtain  the  order  of  the  unknowns  in  the  solution.  In  other  words,  the  final 
solution  is  given  by  P  x  =  b',  where  b'  is  the  last  column  of  the  augmented 
matrix  after  the  solution  has  been  found. 

Example  of  Gauss-Jordan  elimination  with  full  pivoting 

Let's  illustrate  full  pivoting  with  an  example.  Solve  the  following  system  of 
equations  using  full  pivoting  and  the  Gauss-Jordan  elimination  procedure: 

X  +  2Y  +  3Z  =  2, 

2X+        3Z  =  -1, 

8X-I-16Y-Z  =  41. 
The  augmented  matrix  and  the  permutation  matrix  are  as  follows: 


"l 

2 

3 

2" 

"l 

0 

0" 

A  - 

2 

0 

3 

-1 

,    P  = 

0 

1 

0 

8 

16 

-1 

41 

0 

0 

1 

Store  the  augmented  matrix  in  variable  AAUG,  then  press  I  r»  J  CEIIB  to  get  a 
copy  in  the  stack.   We  want  to  keep  the  CSWP  (Column  Swap)  command 
readily  available,  for  which  we  use:  (sD^cm  [alpha) [alpha} (c] (s] [awha]  (find  CSNF'), 
SESSS.   You'll  get  an  error  message,  press  [o^  ],  and  ignore  the  message. 
Next,  get  the  ROW  menu  available  by  pressing:  {^mtm  EiSaiH  S33II!. 

Now  we  are  ready  to  start  the  Gauss-Jordan  elimination  with  full  pivoting. 
We  will  need  to  keep  track  of  the  permutation  matrix  by  hand,  so  take  your 
notebook  and  write  the  P  matrix  shown  above. 
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First,  we  check  the  pivot  a,,.  We  notice  that  the  element  with  the  largest 
absolute  value  in  the  first  row  and  first  column  is  the  value  of  031  =  8.  Since 
we  want  this  number  to  be  the  pivot,  then  we  exchange  rows  1  and  3,  by 
using:  I  /  )lspc][  3  )Inxt]  S3aII3.  The  augmented  matrix  and  the  permutation 
matrix  now  are: 

~  8      16      -1  41 

2      0  3-1 

12       3  2 


0  0  1 
0  1  0 
0  0  1 


Checking  the  pivot  at  position  (1,1)  we  now  find  that  16  is  a  better  pivot  than 
8,  thus,  we  perform  a  column  swap  as  follows:  I  /  }[spc)C2~]l  j^cAr 
The  augmented  matrix  and  the  permutation  matrix  now  are: 


16 

8 

-1 

41 

0 

2 

3 

-1 

2 

1 

3 

2 

0  0  1 

1  0  0 
0  1  0 


Now  we  hove  the  largest  possible  value  in  position  (1,1),  i.e.,  we  performed 
full  pivoting  at  (1,1).  Next,  we  proceed  to  divide  by  the  pivot: 
I  /  Jl  6  Jl  fa  Jl  /  )lnxT]  IEIH3  .  The  permutation  matrix  does  not  change,  but  the 
augmented  matrix  is  now: 


1 

1/2 

-1/16 

41/16 

0 

0 

1 

0 

2 

3 

-1 

1 

0 

0 

2 

1 

3 

2 

0 

1 

0 

The  next  step  is  to  eliminate  the  2  from  position  (3,2)  by  using: 


1     1/2  -1/16  41/16 
0      2  3-1 
0      0     25/8  -25/8 


0  0  1 

1  0  0 
0    1  0 


Having  filled  up  with  zeros  the  elements  of  column  1  below  the  pivot,  now  we 
proceed  to  check  the  pivot  at  position  (2,2).  We  find  that  the  number  3  in 
position  (2,3)  will  be  a  better  pivot,  thus,  we  exchange  columns  2  and  3  by 
using:  CUCeDCU  (JE)-^  ii'^iJi 

r  1  -1/16  1/2  41/16^   r  0  1  01 
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0       3  2-1 
0    25/8      0  -25/82 


1    0  0 

_  0    0    1  _ 

checking  the  pivot  at  position  (2,2),  we  now  find  that  the  value  of  25/8,  at 
position  (3,2),  is  larger  than  3.  Thus,  we  exchange  rows  2  and  3  by  using: 

1  -1/16  1/2  41/16 
0  25/8  0  -25/8 
0      3  2-1 


0    1  0 

0  0  1 

1  0  0 


Now,  we  are  ready  to  divide  row  2  by  the  pivot  25/8,  by  using 

1  -1/16  1/2  41/16  1  To  1  0 
0  10-1  001 
0        3       2-1  1   0  0 


Next,  we  eliminate  the 
CX)  S      CX3      CTD IIMII 

1    -1/16  1/2 
0      1  0 
0      0  2 


3     from     position     (3,2)     by  using: 


41/16 
-1 
2 


0 
0 
1 


0 
1 

0 


Having  filled  with  zeroes  the  position  below  the  pivot,  we  proceed  to  check 
the  pivot  at  position  (3,3).  The  current  value  of  2  is  larger  than  Vi  or  0,  thus, 
we  keep  it  unchanged.  We  do  divide  the  whole  third  row  by  2  to  convert  the 
pivot  to  1,  by  using:  QDCEDCjUKS 


1 

-1/16 

1/2 

41/16 

0 

1 

0 

0 

1 

0 

-1 

0 

0 

1 

0 

0 

1 

1 

1 

0 

0 

Next,  we  proceed  to  eliminate  the  Vi  in  position  (1,3)  by  using: 


1 

0 
0 


-1/16 
1 

0 


0 
0 
1 


33/16 
-1 
1 


0      1  0 

0  0  1 

1  0  0 
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Finally,  we  eliminate  the -1/16  from  position  (1,2)  by  using: 
CZDCX)  CED  CZDC^QD!^] 


1 

0 

0 

2 

0 

1 

0 

-1 

0 

0 

1 

1 

0  1  0 

0  0  1 

1  0  0 


We  now  have  on  identity  matrix  in  the  portion  of  the  augmented  matrix 
corresponding  to  the  original  coefficient  matrix  A,  thus  we  can  proceed  to 
obtain  the  solution  while  accounting  for  the  row  and  column  exchanges  coded 
in  the  permutation  matrix  P.  We  identify  the  unknown  vector  x,  the  modified 
independent  vector  b'  and  the  permutation  matrix  P  as: 


X  = 


~x' 

"2" 

"0 

1 

0" 

Y 

,   b  = 

-1 

,    P  = 

0 

0 

1 

Z 

1 

1 

0 

0 

The  solution  is  given  by  P  x=b',  or 

"0    1  0 

0  0  1 

1  0  0 


Which  results  in 


X 

3 

Y 

-1 

Z 

1 

'y' 

~  3  ' 

z 

-1 

X 

1 

Step-by-step  calculator  procedure  for  solving  linear  systems 

The  example  we  just  worked  is,  of  course,  the  step-by-step,  user-driven 
procedure  to  use  full  pivoting  for  Gauss-Jordan  elimination  solution  of  linear 
equation  systems.  You  can  see  the  step-by-step  procedure  used  by  the 
calculator  to  solve  a  system  of  equations,  without  user  intervention,  by  setting 
the  step-by-step  option  in  the  calculator's  CAS,  as  follows: 
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_V<rb*f«  ^S't<p-'S't<p  _Incr  P*h 


Then,  for  this  particular  example,  in  RPN  mode,  use: 

L J  —  1  ;i  '^■  1  J  [ENTER)  L  L  1  J  i::  J  ^  J  H  L  ^  <  d  j    J  *  L  o  ;i  i  o  j  ■ 


The  calculator  shows  an  augmented  matrix  consisting  of  the  coefficients  matrix 
A  and  the  identity  matrix  I,  while,  at  the  same  time,  showing  the  next 
procedure  to  calculate: 


L2=L2-2.L1 

12    3  10  0 

2  0    3  0  1  0 

S  16  -1  0  0  1 

L2  =  L2-2  L1  stands  for  "replace  row  2  (L2)  with  the  operation  L2  -  2  L1 .  If  we 
had  done  this  operation  by  hand,  it  would  have  corresponded  to: 
CTDC^CzDCTDC^CDEflijS.  Press  I3SII5S,  and  follow  the  operations  in 
your  calculator's  screen.  You  will  see  the  following  operations  performed: 

L3=L3-8  L1,  LI  =  2  L1--1L2,  L1=25  L1-3  L3,  L2  =  25-L2-3-L3, 
and  finally  a  message  indicating  "Reduction  result"  showing: 


deduction  result 
50    0      0   -24  25  3 
0  -100   0   -26  25  -3 
0     0    -25  -S   0  1 


When  you  press  nulSISi,  the  calculator  returns  the  final  result  [1  2  -1]. 
Calculating  the  inverse  matrix  step-by-step 

The  calculation  of  an  inverse  matrix  can  be  considered  as  calculating  the 
solution  to  the  augmented  system  [A  |  I  ].  For  example,  for  the  matrix  A  used 
in  the  previous  example,  we  would  write  this  augmented  matrix  as 


aug(l) 


1     2  3 

3  -2  1 

4  2-1 


1  0  0 
0  1  0 
0   0  1 
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To  see  the  intermediate  steps  in  calculating  and  inverse,  just  enter  the  matrix 
A  from  above,  and  press  I  fc  J ,  v/hile  keeping  the  step-by-step  option  active  in 
the  calculator's  CAS.    Use  the  follov/ing: 

1.  L    .L  J     s  .3  .1  J  I.  -I  H  — J  .L  .1  f  I.     ;i     ;i  —  .L  J  J    [ENTER)  I  'k  J 


After  going  through  the  different  steps,  the  solution  returned  is: 


1: 

0  i  i 

1  -13  1 

S  56  7 
1    3  -1 

.4  23    7  . 

-H:0L  I  COL-f|  COL+  1  COL- 

CSHP  ICREflT 

What  the  calculator  shov/ed  was  not  exactly  a  Gauss-Jordan  elimination  v/ith 
full  pivoting,  but  a  way  to  calculate  the  inverse  of  a  matrix  by  performing  a 
Gauss-Jordan  elimination,  without  pivoting.  This  procedure  for  calculating 
the  inverse  is  based  on  the  augmented  matrix  (A^^igj^xn  =  [Apxn  I'nxnl- 

The  calculator  showed  you  the  steps  up  to  the  point  in  which  the  left-hand  half 
of  the  augmented  matrix  has  been  converted  to  a  diagonal  matrix.  From 
there,  the  final  step  is  to  divide  each  row  by  the  corresponding  main  diagonal 
pivot.  In  other  words,  the  calculator  has  transformed  (Ag„g)„xn  =  [A„xn  I'nxnl; 
into  [I  |A^]. 


Inverse  matrices  and  determinants 

Notice  that  all  the  elements  in  the  inverse  matrix  calculated  above  are  divided 
by  the  value  56  or  one  of  its  factors  (28,  7,  8,  4  or  1).  If  you  calculate  the 
determinant  of  the  matrix  A,  you  get  afe/(A)  =  56. 
We  could  write.  A'  =  C/c/ef(A),  where  C  is  the  matrix 

0      8  8 


C  = 


7  -13  8 
14     6  -8 


The  result  (A\xn  =  C^xn  / def[t^„,X  is  a  general  result  that  applies  to  any  non- 
singular  matrix  A.  A  general  form  for  the  elements  of  C  can  be  written  based 
on  the  Gauss-Jordan  algorithm. 
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Based  on  the  equation      =  C/det(A),  sketched  above,  the  inverse  matrix, 
A\  is  not  defined  if  c/e/(A)  =  0.  Thus,  the  condition  cfe/(A)  =  0  defines  also  a 
singular  matrix. 


Solution  to  linear  systems  using  calculator  functions 

The  simplest  way  to  solve  a  system  of  linear  equations.  A  x  =  b,  in  the 
calculator  is  to  enter  b,  enter  A,  and  then  use  the  division  function  /.    If  the 
system  of  linear  equations  is  over-determined  or  under-determined,  a 
"solution"  can  be  produced  by  using  Function  LSQ  (Least-SQuares),  as  shov/n 
earlier.  The  calculator,  however,  offers  other  possibilities  for  solving  linear 
systems  of  equations  by  using  Functions  included  in  the  MATRICES'  LINEAR 
SYSTEMS.,  menu  accessible  through  r^MAmias  (Set  system  flag  1 17  to 
CHOOSE  boxes): 


HHTRICEf  HEnU 

1.  CREATE.. 
a.OPERflTIOnS.. 
3.FflCT0RIZflTI0n.. 
H. QUADRATIC  FORM.. 

S.LIREAR  SYSTEMS.. 

e.LinEAR  APPL..  1 

1       1       1  icflncL 

OK 

MATRIX  LIREAR  SYS.  MERU 

l.LinSOLVE  1 

2.REF 

3.rr<F 

H.RREF 

S.SVSTaMAT 

MATRICES.. 

HELRl         1         1  ICAiiar 

OK 

The  functions  included  are  LINSOLVE,  REF,  rref,  RREF,  and  SYST2MAT. 


Function  LINSOLVE 

Function  LINSOLVE  takes  as  arguments  an  array  of  equations  and  a  vector 
containing  the  names  of  the  unknowns,  and  produces  the  solution  to  the  linear 
system.  The  following  screens  show  the  help-facility  entry  (see  Chapter  1 )  for 
function  LINSOLVE,  and  the  corresponding  example  listed  in  the  entry.  The 
right-hand  side  screen  shows  the  result  using  the  line  editor  (press  "sj?  to 
activatejj    


LINSOLVE: 
Solves  a  system  of 
linear  equations 
L I HSOLVE  C  [  X-i-V=3 ,  X-V=  1  ] 
, [X,Y]) 

[X=2  Y=l] 

See:  SOLVE 

:HELP 

:LIHS0LVE([X-hY=3  X-Y=1> 
({[X-i-Y=3  X-Y=l]  [X  Y]}  Spe> 
4{:[X-HY=3,X-Y=1], 
[X,Y] J, :Specif ic:  ^2, 
-2,2, 1. J,IX=2,Y=1] J 

EKIT  1  ECHO  1  SEEl  |  SEE2  |  SEE?  |  MAIR 

+^KIP|SKIP-H  H)EL  1  DEL-f|DEL  L|  IRS  ■ 

Here  is  another  example  in  ALG  mode.  Enter  the  following: 
i_.  .L  i-i.3L.ii_  V  i-  V  L  /■■.—^-■r:  I  -r  i:.— -o  i  i::  ?^/-,  r  I  — i- T  i:.— o  i  .j*^— i  +£..——  .l    .J : 
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to  produce  the  solution: 


i  —     in  i  —  iL.  H  I 


Function  LINSOLVE  works  with  symbolic  expressions.  Functions  REF,  rref,  and 
RREF,  work  with  the  augmented  matrix  in  a  Gaussian  elimination  approach. 

Functions  REF,  rref,  RREF 

The  upper  triangular  form  to  which  the  augmented  matrix  is  reduced  during 
the  forward  elimination  part  of  a  Gaussian  elimination  procedure  is  known  as 
an  "echelon"  form.  Function  REF  (Reduce  to  Echelon  Form)  produces  such  a 
matrix  given  the  augmented  matrix  in  stack  level  1 . 

Consider  the  augmented  matrix, 


1 

-2 

1 

0 

A  - 

2 

1 

-2 

-3 

aug 

5 

-2 

1 

12 

Representing  a  linear  system  of  equations,  A-x  =  b,  where 
and 


1    J.  J  .J  , 


Enter  the  augmented  matrix,  and  save  it  into  variable  AAUG,  in  ALG  mode: 


Application  of  function  REF  produces: 


1 1—  X  E  ^ 

l5  -2  1  12 
1-2   1  0 

 10  0    1    7  ^ 


REF(RRUG) 


The  result  is  the  upper  triangular  (echelon  form)  matrix  of  coefficients  resulting 
from  the  forward  elimination  step  in  a  Gaussian  elimination  procedure. 
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The  diagonal  matrix  that  results  from  a  Gauss-Jordan  elimination  is  called  a 
row-reduced  echelon  form.    Function  RREF  (  Row-Reduced  Echelon  Form)  The 
results  of  this  function  coll  is  to  produce  the  row-reduced  echelon  form  so  that 
the  matrix  of  coefficients  is  reduced  to  an  identity  matrix.  The  extra  column  in 
the  augmented  matrix  will  contain  the  solution  to  the  system  of  equations. 

As  an  example,  we  show  the  result  of  applying  function  RREF  to  matrix  AAUG 
in  ALG  mode: 


:RREF(RRUG) 

0  1 

.0  0 

1           ■_■  1 

5  5 
1    7  J 

fl  0  0  31 
0  10  5 
.0  0  1  7J 

HHUG  1         \  fl33  \  EZ?  \  fl33  \  £22 

The  result  is  final  augmented  matrix  resulting  from  a  Gauss-Jordan  elimination 
without  pivoting. 

A  row-reduced  echelon  form  for  an  augmented  matrix  can  be  obtained  by 
using  function  rref.  This  function  produces  a  list  of  the  pivots  and  an 
equivalent  matrix  in  row-reduced  echelon  form  so  that  the  matrix  of 
coefficients  is  reduced  to  a  diagonal  matrix. 

For  example,  for  matrix  AAUG,  function  rref  produces  the  following  result: 


Irref(RRUG) 
Pilots:  {3  1.  4  1.  5  2.>  ^> 


4  1.  s  ii. : 


t :Piyot 

[[20,0,0,60] 

[0, 15,0,75] 
[0,0, 12,34]] J 


{13,  1.  ,4,  1. 


HHUG  1:33 


t^KIP  SKIP-H  H)EL   DEL-f  DEL  L  IHS  i 


The  second  screen  above  is  obtained  by  activating  the  line  editor  (press  *^^). 
The  result  shows  pivots  of  3,  1,4,  1,5,  and  2,  and  a  reduced  diagonal 
matrix. 


Function  SYST2MAT 

This  function  converts  a  system  of  linear  equations  into  its  augmented  matrix 
equivalent.  The  following  example  is  available  in  the  help  facility  of  the 
calculator: 
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HELP 

.  SYST2MRT([X+Y  X-Y=2]  IJ^H 
SYST2MRTaX+Y,  X-Y=2] , 
IX,  YJj)^  

The  result  is  the  augmented  matrix  corresponding  to  the  system  of  equations: 


:HELP 

:  SYST2MRT([X+Y  X 

-Y= 

1     0  1 

11 

-1  -2J 

DEL 

L|  in^  ■ 

X+Y  =  0 
X-Y=2 


Residual  errors  in  linear  system  solutions  (Function  RSD) 

Function  RSD  calculates  the  ReSiDuals  or  errors  in  the  solution  of  the  matrix 
equation  A  x=b,  representing  a  system  of  n  linear  equations  in  n  unknowns. 
We  can  think  of  solving  this  system  as  solving  the  matrix  equation:  f(x)  =  b  - 
A  x  =  0.  Suppose  that,  through  a  numerical  method,  we  produce  as  a  first 
approximation  the  solution  x(0).  Evaluating  f(x(0))  =  b  -  A-x(O)  =  e  jtQ, 
Thus,  e  is  a  vector  of  residuals  of  Function  for  the  vector  x  =  x  (0). 

To  use  Function  RSD  you  need  the  terms  b.  A,  and  x(0),  as  arguments.  The 
vector  returned  is  e  =  b  -  A  x(0).  For  example,  using  A  = 
L  L  2  J  ■- 1  J  L  0  J  2.  J  J ,  x(0)  =  [  1  „  3 II  2.  „  7  ] ,  and  b  =  C  1  j  6  ] ,  we  can  find 
the  vector  of  residuals  as  follows: 


RSDCCl, 
2]], [1. 

6], [[2,-l][0, 
S,2.7]>4 

:RSd[[1  Gill 

[.1  .6] 

t^KIP  SKIP 

■H  H)EL   DEL-f  DEL  L  IDS  ■ 

t^KIP  SKIPH  H)EL 

DEL-f  DEL  L  IDS" 

It  is  e  = 

b-A-x(O)  =  C  0.  1 

0 

.6   .1  . 

Note:  If  we  let  the  vector  Ax  =  x  -  x  (0),  represent  the  correction  in  the 
values  of  x  (0),  we  can  write  a  new  matrix  equation  for  Ax,  namely  A-Ax  = 
e.    Solving  for  Ax  we  can  find  the  actual  solution  of  the  original  system  as  x 
=  x(0)  +  Ax. 
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Eigenvalues  and  eigenvectors 

Given  a  square  matrix  A,  we  can  write  the  eigenvalue  equation  A  x  =  X  x, 
where  the  values  of  X  that  satisfy  the  equation  are  known  as  the  eigenvalues 
of  matrix  A.  For  each  value  of  X,  we  can  find,  from  the  same  equation, 
values  of  x  that  satisfy  the  eigenvalue  equation.  These  values  of  x  are  known 
as  the  eigenvectors  of  matrix  A.   The  eigenvalues  equation  can  be  written 
also  as  (A  -  X-l)x.  =  0. 

This  equation  will  have  a  non-trivial  solution  only  if  the  matrix  (A  -  X-l)  is 
singular,  i.e.,  if  det{A-^-l)  =  0. 

The  last  equation  generates  an  algebraic  equation  involving  a  polynomial  of 
order  n  for  a  square  matrix  A^xn-  The  resulting  equation  is  known  as  the 
characteristic  polynomial  of  matrix  A.  Solving  the  characteristic  polynomial 
produces  the  eigenvalues  of  the  matrix. 

The  calculator  provides  a  number  of  functions  that  provide  information 
regarding  the  eigenvalues  and  eigenvectors  of  a  square  matrix.    Some  of 
these  functions  are  located  under  the  menu  MATRICES/EIGEN  activated 
through  f^mTnias . 


HATRICEf  HEnU 

3.FflCT0RI2flTI0n..  [] 
H. QUADRATIC  FORM..  U 
S.LIREAR  £Y£TEH£..  1 
E.LIREAR  ARPL..  1 

?.EIGEnVECTORS.. 

VECTOR..  1 

1      1      1  icHnoT 

OK 

MATRIX  EIGERVECT.  HERU 

l.DIAGHAP  II 

2.EGV  1 

3.EGVL  1 

H.JORDAR  1 

5.PCAR  1 

C.PHini  D 

HELPi      1      1  IcAnoT 

OK 

Function  PCAR 

Function  PCAR  generates  the  characteristic  polynomial  of  a  square  matrix 
using  the  contents  of  variable  VX  (a  CAS  reserved  variable,  typically  equal  to 
'X')  as  the  unknown  in  the  polynomial.  For  example,  enter  the  following 
matrix  in  ALG  mode  and  find  the  characteristic  equation  using  PCAR: 
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13  5  2J 

[3  5  2J 

:PCRR(RHS(1)) 

-22'X+21 

+^KIP|SKIP^  H)EL  1  DEL-f 

DEL  L|in£> 

Using  the  variable  X  to  represent  eigenvalues,  this  characteristic  polynomial  is 
to  be  interpreted  as  X  ^-2X  ^-22X  +2 1  =0. 

Function  EGVL 

Function  EGVL  (EiGenVaLues)  produces  the  eigenvalues  of  a  square  matrix. 
For  example,  the  eigenvalues  of  the  matrix  shov/n  below  are  calculated  in 
ALG  mode  using  function  EGVL: 


■  [2  -2I 

\2  3 
I2  -2. 

:EGVL(RHS(1)) 

[-■fie  ■JTI. 


+^KIP|SKIP^  H)EL  I  DEL-f|DEL  L|  inS  ■ 


The  eigenvalues  ^  =  [  -Vl  0,  Vl  0  ]. 


Note:  In  some  coses,  you  may  not  be  able  to  find  an  'exact'  solution  to  the 
characteristic  polynomial,  and  you  v/ill  get  on  empty  list  as  a  result  v/hen 
using  Function  EGVL.  If  that  v/ere  to  happen  to  you,  change  the  calculation 
mode  to  Approx  in  the  CAS,  and  repeat  the  calculation. 


For  example,  in  exact  mode,  the  follov/ing  exercise  produces  an  empty  list  as 
the  solution: 


11-21]  ^ 

-2  11 

[1 

-1  2 

-2  iJ 

:EGVL(RHS(1)) 

+^KIP|SKIP^  H)EL  1  DEL-f 

DEL  L 

lins. 
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change  mode  to  Approx  and  repeat  the  entry,  to  get  the  following 
eigenvalues;  L  K  1 ..  Jti  >    .  d'd  >  j   v  1 .      j      .  iii::! )  >   i.  ■■  1 ..  f  'b  j  t1  ^' .] . 


Function  EGV 

Function  EGV  (EiGenValues  and  eigenvectors)  produces  the  eigenvalues  and 
eigenvectors  of  a  square  matrix.  The  eigenvectors  are  returned  as  the 
columns  of  a  matrix,  v/hile  the  corresponding  eigenvalues  are  the  components 
of  a  vector. 


For  example,  in  ALG  mode,  the  eigenvectors  and  eigenvalues  of  the  matrix 
listed  below  are  found  by  applying  function  EGV: 


£-  m  rjiu  1  ■  A.U  1  ■  rjrj 

-1.00   5.00  3.001 
1.00     3.00  4.00J 

2.00   -1.00  1. 
-1.00   5.00  3. 
1.00     3.00  4. 

EGV(RHS(1.00)) 


001 

00 

00J 


=  t 


-1.00  5.00 
1.00  3.00 

EGVtRHSt  1.005) 

1.00     1.00  -0.03 

0.79  -0.51  1.00 
-0.91  0.65  0.34 


00 

00J 


[0.  ► 


+^KIP^KIP-H +«EL   DEL-»  DEL  L  in£  ■H+^KIP^KIP-H +«EL   DEL-»  DEL  L  ID^  ■ 


The  result  shows  the  eigenvalues  as  the  columns  of  the  matrix  in  the  result  list. 
To  see  the  eigenvalues  we  can  use:  GET(ANS(1  ),2),  i.e.,  get  the  second 
element  in  the  list  in  the  previous  result.  The  eigenvalues  are: 


I  nrrETC — i.oo  t.ooj 

:EGV(RHS(1.00)) 

fr  1.00    1.00  -0.031 

0.79  -0.51   1.00    [0. ► 
11-0.91  0.65    0.34  J 
:GET(RHS(1.00),2.00) 

[0.29  3.  16  7.54] 


+^KIP|SKIP^  H)EL  I  DEL-f|DEL  L|  IDS  ■ 


In  summary, 

^1  =  0.29,  Xi  =  [  1. 00,0.79,-0.9 1]\ 
=  3.16,  X2  =  [1.00,-0.51,  0.65]^ 
=  7.54,  Xi  =  [-0.03,  1 .00,  0.84]  \ 


Note:  A  symmetric  matrix  produces  all  real  eigenvalues,  and  its  eigenvectors 
are  mutually  perpendicular.  For  the  example  just  worked  out,  you  can  check 
that  X,  .Xj  =  0,  Xi  .Xj  =  0,  and  Xj  'Xj  =  0. 
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Function  JORDAN 

Function  JORDAN  is  intended  to  produce  the  diagonalization  or  Jordan-cycle 
decomposition  of  a  matrix.  In  RPN  mode,  given  a  square  matrix  A,  function 
JORDAN  produces  four  outputs,  namely: 

•  Tfie  minimum  polynomial  of  matrix  A  (stack  level  4) 

•  The  characteristic  polynomial  of  matrix  A  (stack  level  3) 

•  A  list  with  the  eigenvectors  corresponding  to  each  eigenvalue  of 
matrix  A  (stack  level  2) 

•  A  vector  with  the  eigenvectors  of  matrix  A  (stack  level  4) 

For  example,  try  this  exercise  in  RPN  mode: 

r  r  A     <  -I     r  4     --i       -i  n     r    -"'i       <     i-i  ■!  -i  ir'ii-ir".|-!L  i 

L  I.  '^■  ;i  1  11  -     .1  J  I.  1  ;i     j  —  .L  J  j  I.        j  ""  1  ;i  ti  J  .1  i_H..ir.L-"ni1 

The  output  is  the  following: 

4:  'X'^3+-6*x'^2+2*X+8' 
3:  'X'^3+-6*x'^2+2*X+8' 
2:  {} 
1:  {} 

The  same  exercise,  in  ALG  mode,  looks  as  in  the  following  screen  shots: 


l-^  -1    O  J 

1-2  -1  0  J 

:  JORDRHtRHSd)) 
CX-^3-6*X-^2+2*X+Sj 

*x-^2+2*x+s,{: 

1-2-1  0J 

:  JORDRHtRHS(l)) 

C  X-^3-6*X-^2+2*X+S ,  X-^3-6 

tx-^2+2*x+s,{: 

4X-^3-6*X-^2+2*X+Sj  X-^3- 

=*x-^2+2*x+s, 



DEL-f|DEL  LlinS" 

Function  MAD 

This  function,  although  not  available  in  the  EIGEN  menu,  also  provides 
information  related  to  the  eigenvalues  of  a  matrix.  Function  MAD  is 
available  through  the  MATRICES  OPERATIONS  sub-menu  f^MATRias)  and  is 
intended  to  produce  the  adjoint  matrix  of  a  matrix. 
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In  RPN  mode,  function  MAD  generate  a  number  of  properties  of  a  square 
matrix,  namely: 


•  the  determinant  (stack  level  4) 

•  the  formal  inverse  (stack  level  3), 

•  in  stack  level  2,  the  matrix  coefficients  of  the  polynomial  p(x)  defined 


•    the  characteristic  polynomial  of  the  matrix  (stack  level  1) 

Notice  that  the  equation  (x-l-A)  p(x)=m(x)-l  is  similar,  in  form,  to  the 
eigenvalue  equation  A-x  =  A,-x. 

As  an  example,  in  RPN  mode,  try; 


The  result  is: 

4:  -8. 

3:  [[  0.1 3  -0.25  -0.38][-0.25  0.50  -0.25][-0.38  -0.25  -0.88]] 

2:  {[[1  0  0][0  1  0][0  0  1]]  [[-2  1  -2][1  -4-l][-2-l  -6]  [[-1  2  3][2-4  2][3  2  7]]} 

1:  'X'^3+-6*x'^2+2*X+8' 

The  same  exercise,  in  ALG  mode,  v/ill  look  as  follov/s: 


Matrix  factorization 

Matrix  factorization  or  decomposition  consists  of  obtaining  matrices  that  when 
multiplied  result  in  a  given  matrix.  We  present  matrix  decomposition  through 
the  use  of  Functions  contained  in  the  matrix  FACT  menu.   This  menu  is 
accessed  through  [jjl matrices  . 


by  (x-l-A)  •p{x)=m(x)-l. 


S:i]  MflD 
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HHTRICEf  HEnU 


1.  CREATE.. 
a.OPERflTIOnS.. 


3.FflCT0RIZflTI0n.. 


H. QUADRATIC  FORM.. 
S.LIREAR  SYSTEMS.. 
e.LinEAR  ARPL.. 


MATRIX  FACTOR.  MEnU 


2.LU 

?.CR 

H.qr 

5.SCHUR 

e.SVD 


MATRIX  FACTOR.  HERU 

?.4R  n 

H.qr  y 
5.SCHUR  1 

C.SVD  1 

?.SVL  1 

f.  MATRICES..  II 

1         1         1  ICAnCLl 

OK 

Function  contained  in  this  menu  ore:  LQ,  LU,  QR,SCHUR,  SVD,  SVL 


Function  LU 

Function  LU  takes  as  input  a  square  matrix  A,  and  returns  a  lower-triangular 
matrix  L,  an  upper  triangular  matrix  U,  and  a  permutation  matrix  P,  in  stack 
levels  3,  2,  and  1,  respectively.  The  results  L,  U,  and  P,  satisfy  the  equation 
P-A  =  L-U.  When  you  call  the  LU  function,  the  calculator  performs  a  Crout 
LU  decomposition  of  A  using  partial  pivoting. 

For  example,  in  RPN  mode:  [  [  - 1 ,  2 , 15  ]  [  3 ,  1 ,  ~2  ]  C  7 ,  6 :,  5 1 11  LU 
produces: 

3:[[7  0  0][-1  2.86  0][3 -1.57-1] 
2:  [[1  0.86  0.71][0  1  2][0  0  1]] 
1:  [[0  0  1][1  0  0][0  1  0]] 
In  ALG  mode,  the  same  exercise  will  be  shown  as  follows: 


3.00  1.00-2.001 

7.00  6.00  5.00J 
LU(RH3(1.00)) 

00  0.00  0.00  1  ri.e 

1.00   2.36     0.00       0.  ► 

00  -1.57  -1.00J  l0.e 


:  LU 

IK 


4 

[[7. 

,0. ,0. ] 

[-1 

.  ,2.35714235714, 

0... 

[3. 

,-1.57142357143, 

[[1. 

, .357142357143, . 

7'.". 

[0. 

jl. j2.] 

[0. 

,0. , 1. ]] 

+^KIP|SKIP-H  H)EL  1  DEL-f|DEL  L|  IRS  ■ 

Orthogonal  matrices  and  singular  value  decomposition 

A  square  matrix  is  said  to  be  orthogonal  if  its  columns  represent  unit  vectors 
that  are  mutually  orthogonal.  Thus,  if  we  let  matrix  U  =  [v,      ...  vj  where 
the  Vj,  i  =  1,  2,      n,  are  column  vectors,  and  if  V|»Vj  =  6ij,  where  8,1  is  the 
Kronecker's  delta  function,  then  U  will  be  an  orthogonal  matrix.  This 
conditions  also  imply  that  U-      =  I. 
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The  Singular  Value  Decomposition  (SVD)  of  a  rectangular  matrix  A^^n  consists 
in  determining  the  matrices  U,  S,  and  V,  such  that  A^xn  =  U         mxn  V  ^  ^xn/ 
where  U  and  V  are  orthogonal  matrices,  and  S  is  a  diagonal  matrix.  The 
diagonal  elements  of  S  are  called  the  singular  values  of  A  and  are  usually 
ordered  so  that  s,  >s,+,,  for  i  =  1 ,  2,      n-1 .  The  columns  [U|]  of  U  and  [V|]  of 
V  are  the  corresponding  singular  vectors. 

Function  SVD 

In  RPN,  function  SVD  (Singular  Value  Decomposition)  takes  as  input  a  matrix 
A„xmj  and  returns  the  matrices  Upxp/  V^xm/  ond  a  vector  s  in  stack  levels  3,  2, 
and  1 ,  respectively.  The  dimension  of  vector  s  is  equal  to  the  minimum  of  the 
values  n  and  m.  The  matrices  U  and  V  are  as  defined  earlier  for  singular 
value  decomposition,  v/hile  the  vector  s  represents  the  main  diagonal  of  the 
matrix  S  used  earlier. 

For  example,  in  RPN  mode:  [  [  5  j  4  j  —  1  j  j  11 2  <  —3  ?  Iii  11  j  11 7  ;i  2  j  8  j  11  SVD 

3:  [[-0.27  0.81  -0.53][-0.37 -0.59 -0.72][-0.89  3.09E-3  0.46]] 
2:  [[  -0.68  -0.14  -0.72][  0.42  0.73  -0.54][-0.60  0.67  0.44]] 
1:  [  12.15  6.88  1.42] 

Function  SVL 

Function  SVL  (Singular  Values)  returns  the  singular  values  of  a  matrix  A„xm  as 
a  vector  s  v^hose  dimension  is  equal  to  the  minimum  of  the  values  n  and  m. 
For  example,  in  RPN  mode,  [  C  5  j  4 ,  - 1  IljC  2 :,  -3 ,  5 IIJI 7 :,  2  h  3  il  3  SVL. 
produces  [12.15  6.88  1.42]. 

Function  SCHUR 

In  RPN  mode,  function  SCHUR  produces  the  Schur  decomposition  of  a  square 
matrix  A  returning  matrices  Q  and  T,  in  stack  levels  2  and  1,  respectively, 
such  that  A  =  Q  T  Q\  v/here  Q  is  an  orthogonal  matrix,  and  T  is  a  triangular 
matrix.    For  example,  in  RPN  mode, 

tr  ■-!  —I  -I  T  r  c"  /I  ■-!  -I  r  cr  a  -i  t  ^--i-'I  ii  ir-i 
I.    s  .3  s  ~  .L  J  L  _i  J  --I-  J  — ,i  J  L  f  J  -J  J 't  .1  J  o(_-rTUri 

results  in: 

2:  [[0.66 -0.29 -0.70][-0.73 -0.01  -0.68][ -0.19 -0.96  0.21]] 
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1 :  [[-1 .03  1 .02  3.86  ][  0  5.52  8.23  ][  0  -1 .82  5.52]] 
Function  LQ 

The  LQ  function  produces  the  LQ  factorization  of  a  matrix  A^xm  returning  a 
lower  Lnxm  trapezoidal  matrix,  a  Q^xm  orthogonal  matrix,  and  a  P„x„ 
permutation  matrix,  in  stack  levels  3,  2,  and  1 .   The  matrices  A,  L,  Q  and  P 
are  related  by  P  A  =  L  Q.  (A  trapezoidal  matrix  out  of  an  nxm  matrix  is  the 
equivalent  of  a  triangular  matrix  out  of  an  nxn  matrix).  For  example, 
LI.  1  ;i  — i-j    .lJL         ij  — .iJL  -J  J  — J    1  J  .1  i_.U 

produces 

3:  [[-5.48  0  0][-l .  1 0  -2.79  0][-l  .83  1 .43  0.78]] 

2:  [[-0.91  0.37  -0.18]  [-0.36  -0.50  0.79]  [-0.20  -0.78  -0.59]] 

1:  [[0  0  1][0  1  0][1  0  0]] 

Function  QR 

In  RPN,  function  QR  produces  the  QR  factorization  of  a  matrix  A^^^  returning 

a  Qnxn  orthogonal  matrix,  a  R„^^  upper  trapezoidal  matrix,  and  a  P^xm 

permutation  matrix,  in  stack  levels  3,  2,  and  1 .  The  matrices  A,  P,  Q  and  R 

are  related  by  A-P  =  Q-R.  For  example, 

I.  L  .L  J  — ;i  J.  J  I.     n  ■!■  J       -I  L  -'J       s  1  .J  J  y.r-. 

produces 

3:  [[-0.18  0.39  0.90][-0.37 -0.88  0.30][-0.91  0.28  -0.30]] 
2:  [[  -5.48  -0.37  1 .83][  0  2.42  -2.20][0  0  -0.90]] 

1:  [[1  0  0][0  0  1][0  1  0]]  

Note:  Examples  and  definitions  for  all  functions  in  this  menu  are  available 
through  the  help  facility  in  the  calculator.  Try  these  exercises  in  ALG  mode  to 
see  the  results  in  that  mode. 


Matrix  Quadratic  Forms 

A  quadratic  form  from  a  square  matrix  A  is  a  polynomial  expression 
originated  from  x-A-x^.  For  example,  if  we  use  A  =  [[2, l,-1][5,4,2][3,5,- 
l]],  and  X  =  [X  Y  Z]^,  the  corresponding  quadratic  form  is  calculated  as 
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Finally, 


x-A-x^=[X    Y  Z] 


=  [X    Y  Z] 


xAx^ 


2  1  -1  X 
5    4  2-7 

3  5    -1  Z 
2X  +  Y-Z 

5X  +  4Y  +  2Z 
3X  +  5Y-Z 
2X2+4Y2-Z2+6XY+2XZ+7ZY 


The  QUADF  menu 

The  HP  49  G  calculator  provides  the  QUADF  menu  for  operations  related  to 
QUADratic  Forms.  The  QUADF  menu  is  accessed  through  I  <i  ] matrices  . 


HATRICEf  HEnU 

1.  CREATE..  1 
a.OFERATIOn^..  1 
^.FACTORIZATIOn..  1 

H.eUADRflTIC  FORM.. 

S.LIREAR  £Y£TEH£..  H 
e.LinEAR  APPL..  U 

1         1         1  ICHTKiT 

OK 

HATRIK  CUAD. 

FORM  HEnU 

l.AKt 

a.CHOLESKV 

?.GAU££ 

H.CXA 

5. SYLVESTER 
MATRICES.. 

ICAACLl 

OK 

This  menu  includes  functions  AXQ,  CHOLESKY,  GAUSS,  QXA,  and 
SYLVESTER. 


Function  AXQ 

In  RPN  mode,  function  AXQ  produces  the  quadratic  form  corresponding  to  a 
matrix  A„xn  in  stack  level  2  using  the  n  variables  in  a  vector  placed  in  stack 
level  1 .  Function  returns  the  quadratic  form  in  stack  level  1  and  the  vector  of 
variables  in  stack  level  1 .  For  example, 


[  L  2  J  In  ■■-  1  J  5  L  5  J  4  J  2  J  J  L  3  !  D  J  -  1  J  J  (fNTH) 
I.    f\    J      I     ;i  J  [ENTER)  MrtW 

returns 

2:  '2*X'^2+(6*Y+2*Z)*X+4*Y'^2+7*Z*y-Z'^2' 
1 :  ['X'  'Y'  'Z'] 
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Function  QXA 

Function  QXA  takes  as  arguments  a  quadratic  form  in  stack  level  2  and  a 
vector  of  variables  in  stack  level  1 ,  returning  the  square  matrix  A  from  wfiicfi 
the  quadratic  form  is  derived  in  stack  level  2,  and  the  list  of  variables  in  stack 
level  1 .    For  example, 

[' '  'A'     V "'  ,  '  Z  '  :i'       Q'Xf=l""  ^ 

returns 

2:  [[1  2-8][2  1  0][-8  0-1]] 
1 :  ['X'  'Y'  'Z'] 

Diagonal  representation  of  a  quadratic  form 

Given  a  symmetric  square  matrix  A,  it  is  possible  to  "diagonalize"  the  matrix 
A  by  finding  an  orthogonal  matrix  P  such  that  P^  A  P  =  D,  where  D  is  a 
diagonal  matrix.    If  Q  =  x-A-x^  is  a  quadratic  form  based  on  A,  it  is  possible 
to  write  the  quadratic  form  Q  so  that  it  only  contains  square  terms  from  a 
variable  y,  such  that  x  =  P-y,  by  using  Q  =  x-A-x^=  (P  y)-A-  (P-y)^  = 
y  (PT  A  P)  yT  =  yDy\ 

Function  SYLVESTER 

Function  SYLVESTER  takes  as  argument  a  symmetric  square  matrix  A  and 
returns  a  vector  containing  the  diagonal  terms  of  a  diagonal  matrix  D,  and  a 
matrix  P,  so  that  P^  A  P  =  D.  For  example, 

rr-~iH        4  "1     r  ■*     A    -f-t-i     r     i     J~i       hit     r-i.M  i  ii— r^T"!:-!-i 

I.  L  i-  J  1 J  ~  1  J  5  L  1 J  4 )    J  J  I.  —  1  J    J  —  1  J  J    o  M_  V  i- 1 1 K 

produces 

2:  [  1/2  2/7  -23/7] 

1:  [[2  1  -l][0  7/2  5/2][0  0  1]] 

Function  GAUSS 

Function  GAUSS  returns  the  diagonal  representation  of  a  quadratic  form  Q  = 
x-A  x^  taking  as  arguments  the  quadratic  form  in  stack  level  2  and  the  vector 
of  variables  in  stack  level  1 .  The  result  of  this  function  call  is  the  following; 

•  An  array  of  coefficients  representing  the  diagonal  terms  of  D  (stack 

level  4) 

•  A  matrix  P  such  that  A  =  P^-D-P  (stack  level  3) 

•  The  diagonalized  quadratic  form  (stack  level  2) 
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•  The  list  of  variables  (stack  level  1) 
For  example, 


returns 

4:  [1  -0.333  20.333] 

3:  [[1  2-8][0-3  16][0  0  1]] 

2:  '61/3*Z'^2+-l/3*(16*Z+-3*Y)'^2+(-8*z+2*Y+X)'^2' 
1 :  ['X'  'Y'  'Z'] 


Linear  Applications 


MATRICES  MERU 

3.FACT0RI2ATI0n..  [] 
H. QUADRATIC  FORM..  U 
S.LIREAR  SYSTEMS..  1 

CLIREAR  APPL.. 

^.EICERVECTORS..  1 
VECTOR..  1 

1       1       1  IcSnor 

OK 

LIREAR  ARRL  MERU 

1. IMAGE  1 

2.IS0M 
3.KER 
H.MKISOM 
E. MATRICES.. 

HELRI         1         1  ICARCLI 

OK 

Information  on  the  functions  listed  in  this  menu  is  presented  below  by  using  the 
calculator's  own  help  facility.  The  figures  show  the  help  facility  entry  and  the 
attached  examples. 

Function  lAAAGE 


IMAGE: 

Image  of 

a  linear 

ap- 

pl icat  ion 

of  matri 

X  M 

IMflGEaCl 

,2,3], [4, 

5,6] 

iZl    0]  [0 

1]3 

See:  KER 

BRSIS 

EKIT  1  ECHO  1  SEEl  |  SEE2  |  SEE? 

1  MAin 

HELP 


{[1  0]  [0  1]} 


Function  ISOM 


Fincds  elements  of 
2-cd  or  3-cd  linear 
isometry 

ISOMacSj-l],  [1,0]]> 


L  1  CJ  J  J  / 


13 


See:  MKISOM 


EKIT   ECHO   SEEl   SEE2   SEE?   MAIR  HCASCM  HELP 
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Function  KER 


Kernel  of  a  linear  ap-| 
Plication  of  matrix  M 
<ER<[C1,2,3], C4,5,6]]> 

See:  IMRGE 


EXIT   ECHO   f  EEl   £EE2   iZZ3   HHIH  HCH^CH  HELP 


Function  MKISOM 


MKISOM: 

flake  an  isometry  given 
its  elements 

[[-1,0], [0,-1]] 

See:  ISOM 


EHIT   ECHO   f  EEl   £EE2   iZZ3   HHIH  HCH^CH  HELP 


:HELP 

:MKISOMCTr,l) 

r-1  0  1 

I  0  -iJ 

CflSCHIHELPI         1         1  1 
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Chapter  1 2 
Graphics 

In  this  chapter  we  introduce  some  of  the  graphics  capabilities  of  the  calculator. 
We  will  present  graphics  of  functions  in  Cartesian  coordinates  and  polar 
coordinates,  parametric  plots,  graphics  of  conies,  bar  plots,  scatterplots,  and 
a  variety  of  three-dimensional  graphs. 


Graphs  options  in  the  calculator 

To  access  the  list  of  graphic  formats  available  in  the  calculator,  use  the 
keystroke  sequence  UxJJMd.  {(jU  )    Please  notice  that  if  you  are  using  the 
RPN  mode  these  two  keys  must  be  pressed  simultaneously  to  activate  any  of 
the  graph  functions.  After  activating  the  2D/3D  function,  the  calculator  will 
produce  the  PLOT  SETUP  window,  which  includes  the  TYPE  field  as  illustrated 
below. 


^^^^F-LOT  SETUPS 

^:R0d 

EC: 

Ind«p:l{  SiHULt 

H-Tich:lD.  V-Tich:lD. 

ch**fs  taps  *f  put 

Right  in  front  of  the  TYPE  field  you  will,  most  likely,  see  the  option  Function 
highlighted.   This  is  the  default  type  of  graph  for  the  calculator.  To  see  the 
list  of  available  graph  types,  press  the  soft  menu  key  labeled  IHIIiffil.    This  will 
produce  a  drop  down  menu  with  the  following  options  (use  the  up-  and  down- 
arrow  keys  to  see  all  the  options): 


Tap* 

EC: 


H-Ti 


Diff  Eq 
C*riic 
Truth 
Hift^jroH 


Rod 


nsct 
Hi 


Taps 

EC: 


InOs 
H-Ti 


S  Upsfis  1.0 

FoftJD 

HirsFroHS 

Pf-C^ntour 

V-Slics 

GridHop 


Pr-SurFocs 


Rod 


CHnCL  OH 


Taps 

EC: 

Inds 
H-Ti 

tor 

Scottsr 
SUpsFisLd 
FoftJD 
HirsFroHS 

Rod 

nsct 
sL; 
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These  graph  options  ore  described  briefly  next. 

Function:  for  equations  of  the  form  y  =  f(x)  in  plane  Cartesian  coordinates 
Polar,  for  equations  of  the  from  r  =  f(9)  in  polar  coordinates  in  the  plane 
Parametric:  for  plotting  equations  of  the  form  x  =  x(t),  y  =  y(t)  in  the  plane 
Diff  Eq:  for  plotting  the  numerical  solution  of  a  linear  differential  equation 
Conic:  for  plotting  conic  equations  (circles,  ellipses,  hyperbolas,  parabolas) 
Truth:  for  plotting  inequalities  in  the  plane 

Histogram:  for  plotting  frequency  histograms  (statistical  applications) 
Bar.  for  plotting  simple  bar  charts 

Scatter  for  plotting  scatter  plots  of  discrete  data  sets  (statistical  applications) 
Slopefield:  for  plotting  traces  of  the  slopes  of  a  function  f(x,y)  =  0. 
Fast3D:   for  plotting  curved  surfaces  in  space 

Wireframe:  for  plotting  curved  surfaces  in  space  shov/ing  v/ireframe  grids 

Ps-Contour:  for  plotting  contour  plots  of  surfaces 

Y-  Slice:  for  plotting  a  slicing  view  of  a  function  f(x,y). 

Gridmap:  for  plotting  real  and  imaginary  part  traces  of  a  complex  function 

Pr-Surface:  for  parametric  surfaces  given  by  x  =  x(u,v),  y  =  y(u,v),  z  =  z(u,v). 

Plotting  an  expression  of  the  form  /  =  ffxj 

in  this  section  we  present  an  example  of  a  plot  of  a  function  of  the  form  y  = 
f(x).  In  order  to  proceed  with  the  plot,  first,  purge  the  variable  x,  if  it  is 
defined  in  the  current  directory  (x  will  be  the  independent  variable  in  the 
calculator's  PLOT  feature,  therefore,  you  don't  want  to  have  it  pre-defined). 
Create  a  sub-directory  called  'TPLOT'  (for  test  plot),  or  other  meaningful  name, 
to  perform  the  following  exercise. 
As  an  example,  let's  plot  the  function. 


•  First,  enter  the  PLOT  SETUP  environment  by  pressing,  [jjJ^SMi  .  Make 
sure  that  the  option  Function  is  selected  as  the  TYPE,  and  that  'X'  is 
selected  as  the  independent  variable  (INDEP).     Press  L^^iJiiiiiDlB  to 
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return  to  normal  calculator  display.  The  PLOT  SET  UP  window  should 
look  similar  to  this; 


EC: 

H-Tich:lD.  V-Tich:lD. 

ch**f<  ■tap<  *f  put 

HXEf ■  ERA^E  DRAH 


•  Note:  You  will  notice  that  a  new  variable,  called  PPAR,  shows  up  in 
your  soft  menu  key  labels.  This  stands  for  Plot  PARameters.  To  see  its 
contents,  press  I  r»  J[i33j.  A  detailed  explanation  of  the  contents  of 
PPAR  is  provided  later  in  this  Chapter.  Press  I  4  J  to  drop  this  line 
from  the  stack. 


•     Enter  the  PLOT  environment  by  pressing  UiJJ^  (press  them 
simultaneously  if  in  RPN  mode).  Press  lLiE[i!l  to  get  you  into  the 
equation  writer.  You  will  be  prompted  to  fill  the  right-hand  side  of  an 
equation  Yl  (x)  =  ■.  Type  the  function  to  be  plotted  so  that  the 
Equation  Writer  shows  the  following:  

_!<! 


EDIT  I  CUR£  I  EIG  ■!  EVAL  |FACTO|  £IHR 


•  Press  tfMH)  to  return  to  the  PLOT  SETUP  window.  The  expression 
'Yl  (X)  =  EXP(-X'^2/2)/V(2*7i)'  will  be  highlighted.  Press  (W]liEIIil  to 
return  to  normal  calculator  display. 


Note:  Two  new  variables  show  up  in  your  soft  menu  key  labels,  namely 
EQ  and  Yl .  To  see  the  contents  of  EQ,  use  U^lilill.  The  content  of  EQ 
is  simply  the  function  name  'Yl(X)'.  The  variable  EQ  is  used  by  the 
calculator  to  store  the  equation,  or  equations,  to  plot. 

To  see  the  contents  of  Yl  press  (.  r»  JiiSji.  You  will  get  the  function  Y1(X) 
defined  as  the  program: 
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«         'EXP  {-X'^2/2)  /  V(2*7r) '  ». 
Press  I    J,  twice,  to  drop  the  contents  of  the  stock. 


•     Enter  the  PLOT  WINDOW  environment  by  entering  (^3 ML  (press 

them  simultaneously  if  in  RPN  mode).     Use  a  range  of  -4  to  4  for  H- 

VI EW,  then  press  IliEiii]  to  generate  the  V-VIEW  automatically.  The 
PLOT  WINDOW  screen  looks  as  follows: 


PLOT  HinPOH  - 
V-Vi<H:-5.SS3?H 


FuncTion^^ 

H. 


HUTO  ERA^E  DRAH 


•  Plot  the  graph:  il33al  G33j  (wait  till  the  calculator  finishes  the 
graphs) 

•  To  see  labels:    iilLlijllj!  (W]  rilljT!] 

•  To  recover  the  first  graphics  menu:  [nxt }Inxt jiWSi 

•  To  trace  the  curve:  IBCSjEu  E3!!iS  .  Then  use  the  right-  and  left-arrow 
keys  (Cj)®)  to  move  about  the  curve.  The  coordinates  of  the  points 
you  trace  will  be  shown  at  the  bottom  of  the  screen.  Check  that  for  x 
=  1.05  ,  y  =  0.231.  Also,  check  that  for  x  =  -1 .48  ,  y  =  0.134. 
Here  is  picture  of  the  graph  in  tracing  mode: 


\ 

V:1.SDE-1 

•    To  recover  the  menu,  and  return  to  the  PLOT  WINDOW  environment, 
press  [nxt]^.  ....i,L .,  then  [NxTjMIM. 
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Some  useful  PLOT  operations  for  FUNCTION  plots 

In  order  to  discuss  these  PLOT  options,  we'll  modify  the  function  to  force  it  to 
have  some  real  roots  (Since  the  current  curve  is  totally  contained  above  the  x 
axis,  it  has  no  real  roots.)  Press  L  r»  jWiiM  to  list  the  contents  of  the  function 
Yl  on  the  stack:  «  'EXP(-X''2/2)/  V(2*7r)  '  ».  To  edit  this  expression 
use: 


OD  C3D  CD  Q  CE  a  CD 

[ENTlIt] 


Launches  the  line  editor 
Moves  cursor  to  the  end  of  the  line 
Modifies  the  expression 
Returns  to  calculator  display 


Next,  store  the  modified  expression  into  variable  y  by  using  (.  *i  J 
RPN  mode,  or  CfD^^^«-  QroT)  lEIil  in  ALG  mode. 


if  in 


The  function  to  be  plotted  is  nov^,  f{x) 


1  r- 

exp(-— )-0.1 


Enter  the  PLOT  WINDOW  environment  by  entering  C^D-M,  (press  them 
simultaneously  if  in  RPN  mode.)  Keep  the  range  of  -4  to  4  for  H-VIEW, 
press  ^!3Ili]3  to  generate  the  V-VIEW.  To  plot  the  graph,  press  Hailla  Eal" 

•  Once  the  graph  is  plotted,  press  isl^lill  to  access  the  function  menu. 
With  this  menu  you  can  obtain  additional  information  about  the  plot 
such  as  intersects  with  the  x-axis,  roots,  slopes  of  the  tangent  line, 
area  under  the  curve,  etc. 

•  For  example,  to  find  the  root  on  the  left  side  of  the  curve,  move  the 
cursor  near  that  point,  and  press  IHulEEi.  You  will  get  the  result:  ROOT: 
-1.6635....   Press  (nxtJ  to  recover  the  menu.      Here  is  the  result  of 


1553 
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•  If  you  move  the  cursor  towards  the  right-hand  side  of  the  curve,  by 
pressing  the  right-arrow  key  (CD),  and  press  iiSSii,  the  result  now  is 
ROOT:  1.6635...  The  calculator  indicated,  before  showing  the  root, 
that  it  was  found  through  SIGN  REVERSAL.  Press  [nxt]  to  recover  the 

menu. 

•  Pressing  ItiBliS  will  give  you  the  intersection  of  the  curve  with  the  x- 
axis,  which  is  essentially  the  root.  Place  the  cursor  exactly  at  the  root 
and  press  You  will  get  the  same  message  as  before,  namely 
SIGN  REVERSAL,  before  getting  the  result  l-SECT:  1.6635....  The 
Sij^loll  function  is  intended  to  determine  the  intersection  of  any  two 
curves  closest  to  the  location  of  the  cursor.  In  this  case,  where  only 
one  curve,  namely,  Yl  (X),  is  involved,  the  intersection  sought  is  that  of 
f(x)  with  the  x-axis,  however,  you  must  place  the  cursor  right  at  the 
root  to  produce  the  same  result.  Press  [nxt]  to  recover  the  menu. 

•  Place  the  cursor  on  the  curve  at  any  point  and  press  ItilEIiEj  to  get  the 
value  of  the  slope  at  that  point.  For  example,  at  the  negative  root, 
SLOPE:  0.16670....  Press        to  recover  the  menu. 

•  To  determine  the  highest  point  in  the  curve,  place  the  cursor  near  the 
vertex  and  press  lEIElIE]  The  result  is  EXTRM:  0..  Press  [nxt)  to  recover 
the  menu. 

•  Other  buttons  available  in  the  first  menu  are  iMsh  to  calculate  the 
area  under  the  curve,  and  ESEHa  to  shade  an  area  under  the  curve. 
Press  tjwrj  to  see  more  options.  The  second  menu  includes  one  button 
called  Bliliil]  that  flashes  for  a  few  seconds  the  equation  plotted.  Press 
iBIjIII.  Alternatively,  you  can  press  the  button  luESS  (NEXt  eOuation)  to 
see  the  name  of  the  function  Yl  (x).  Press  [hxt]  to  recover  the  menu. 

•  The  button  gives  the  value  of  f(x)  corresponding  to  the  cursor 
position.  Place  the  cursor  anywhere  in  the  curve  and  press  iU(il)lll.  The 
value  will  be  shown  in  the  lower  left  corner  of  the  display.  Press  L^xt-j 
to  recover  the  menu. 

•  Place  the  cursor  in  any  given  point  of  the  trajectory  and  press  TANL 
to  obtain  the  equation  of  the  tangent  line  to  the  curve  at  that  point. 
The  equation  will  be  displayed  on  the  lower  left  corner  of  the  display. 
Press  [NXT)  to  recover  the  menu. 

•  If  you  press  the  calculator  will  plot  the  derivative  function,  f'(x) 
=  df/dx,  as  well  as  the  original  function,  f(x).    Notice  that  the  two 
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curves  intercept  at  two  points.  Move  the  cursor  near  the  left  intercept 
point  and  press  SM  ^EMi,  to  get  l-SECT:  (-0.6834.. .,0.21 585). 
Press  [NXTj  to  recover  the  menu. 

•  To  leave  the  FCN  environment,  press  llljlljl  (or  jIlLiiLlI). 

•  Press  iiiMlf  to  return  to  the  PLOT  WINDOW  environment.  Then, 
press  [nxT}  "iiv:!"!:::'  to  return  to  normal  calculator  display. 


Note:  the  stock  v/ill  show  all  the  graph  operations  performed,  properly 
identified. 


•  Enter  the  PLOT  environment  by  pressing,  simultaneously  if  in  RPN 
mode,  (3D^.  Notice  that  the  highlighted  field  in  the  PLOT 
environment  now  contains  the  derivative  of  Y1(X).  Press  (W]IE!3bIS  to 
return  to  return  to  normal  calculator  display. 

•  Press  I  r»  J 18138  to  check  the  contents  of  EQ.  You  will  notice  that  it 
contains  a  list  instead  of  a  single  expression.  The  list  has  as  elements 
an  expression  for  the  derivative  of  Y1(X)  and  Y1(X)  itself. 
Originally,  EQ  contained  only  Yl(x).   After  we  pressed  mm'  m  in  the 

environment,  the  calculator  automatically  added  the  derivative  of 
Yl  (x)  to  the  list  of  equations  in  EQ. 

Saving  a  graph  for  future  use 

if  you  want  to  save  your  graph  to  a  variable,  get  into  the  PICTURE 
environment  by  pressing  C3D .  Then,  press  IliGIEii Inxt][nxt) EEmj^ .  This 
captures  the  current  picture  into  a  graphics  object.  To  return  to  the  stack, 
press  uLisM  laAiuas. 

In  level  1  of  the  stack  you  will  see  a  graphics  object  described  as  Graphic 
131  X  64.  This  can  be  stored  into  a  variable  name,  say,  PICl . 

To  display  your  figure  again,  recall  the  contents  of  variable  PICl  to  the  stack. 
The  stack  will  show  the  line:  Graphic  131  x  64.  To  see  the  graph,  enter 
the  PICTURE  environment,  by  pressing  C3D  . 

Clear  the  current  picture,  fSSMlNXTjUmai. 
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Move  the  cursor  to  the  upper  left  corner  of  the  display,  by  using  the  C3D 
and  keys. 

To  display  the  figure  currently  in  level  1  of  the  stack  press  [A/xrj  REPL  . 
To  return  to  normal  calculator  function,  press  iCtaSII  laHIiS. 


Note:  To  save  printing  space,  we  v/ill  not  include  more  graphs  produced  by 
follov/ing  the  instructions  in  this  Chapter.  The  user  is  invited  to  produce  those 
graphics  on  his  or  her  own. 


Graphics  of  transcendental  functions 

In  this  section  we  use  some  of  the  graphics  features  of  the  calculator  to  show 
the  typical  behavior  of  the  natural  log,  exponential,  trigonometric  and 
hyperbolic  functions.  You  will  not  see  more  graphs  in  this  chapter,  instead 
the  user  should  see  them  in  the  calculator. 

Graph  of  ln(X) 

Press,  simultaneously  if  in  RPN  mode,  the  left-shift  key  I  *i  J  and  the  (ffT] ) 
key  to  produce  the  PLOT  SETUP  window.  The  field  labeled  Type  will  be 
highlighted.  If  the  option  Function  is  not  already  selected  press  the  soft  key 
labeled  sjilll^!y!§,  use  the  up  and  down  keys  to  select  Function,  and  press  Hiiilljii 
to  complete  the  selection.  Check  that  the  field  labeled  Indep:  contains  the 
variable  'X'.  If  that  is  not  so,  press  the  down  arrow  key  twice  until  the  indep 
field  is  highlighted,  press  the  soft  key  labeled  isliliiyjl  and  modify  the  value  of 
the  independent  variable  to  read  'X'.  Press  BUI  when  done.  Press 
lNXT)muS3S  to  return  to  normal  calculator  display. 

Next,  we'll  resize  the  plot  window.  First,  press,  simultaneously  if  in  RPN 
mode,  the  left-shift  key  L  *i  J  and  the  Jt^  (CjD  )  key  to  produce  the  PLOT- 
FUNCTION  window.  If  there  is  any  equation  highlighted  in  this  window, 
press  as  needed  to  clear  the  window  completely.     When  the  PLOT- 

FUNCTION  window  is  empty  you  will  get  a  prompt  message  that  reads:  No 
Equ. ,  Press  ADD.    Press  the  soft  key  labeled    wSSSm  .  This  will  trigger  the 
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equation  writer  with  the  expression  Yl(X)=-<  .  Type  LN(X).  Press  Isfs)  to 
return  to  the  PLOT-FUNCTION  window.  Press  (.A/xrjilEilii  to  return  to  normal 
calculator  display. 

The  next  step  is  to  press,  simultaneously  if  in  RPN  mode,  the  left-shift  key  (Jjj 
and  the  J!*L  (GQ  )  key  to  produce  the  PLOT  WINDOW  -  FUNCTION  window. 
Most  likely,  the  display  will  show  the  horizontal  (H-View)  and  vertical  (v-view) 
ranges  as:  H-View: -6.5       6.5,  V-View:-3.1  3.2 

These  are  the  default  values  for  the  x-  and  y-range,  respectively,  of  the  current 
graphics  display  window.  Next,  change  the  H-View  values  to  read:  H-View:  -1 
10  by  using  L/_J IjjzJ ^ ° L/J LOJ ilillill .  Next,  press  the  soft  key  labeled 
ITIIIIjly  to  let  the  calculator  determine  the  corresponding  vertical  range.  After  a 
couple  of  seconds  this  range  will  be  shown  in  the  PLOT  WINDOW- 
FUNCTION  window.  At  this  point  we  are  ready  to  produce  the  graph  of 
ln(X).  Press  laaiSai  Siiiili  to  plot  the  natural  logarithm  function. 

To  odd  labels  to  the  graph  press  Ollilj^iJlIM^^^  Press  KalG  to  remove  the 
menu  Igbels,  gnd  get  g  full  view  of  the  grgph.  Press  [nxtJ  to  recover  the 
current  graphic  menu.  Press  lnxT}mMM  to  recover  the  original  graphical  menu. 

To  determine  the  coordinates  of  points  on  the  curve  press  IlLiljilMil  (the  cursor 
moves  on  top  of  the  curve  at  a  point  located  near  the  center  of  the  horizontal 
range).  Next,  press  (X,Y)  to  see  the  coordinates  of  the  current  cursor 
location.  These  coordinates  will  be  shown  at  the  bottom  of  the  screen.  Use 
the  right-  and  left-arrow  keys  to  move  the  cursor  along  the  curve.  As  you 
move  the  cursor  along  the  curve  the  coordinates  of  the  curve  are  displayed  at 
the  bottom  of  the  screen.  Check  that  when  Y:l  .OOEO,  X:2.72E0.  This  is  the 
point  (e,  /),  since  ln(e)  =  1.  Press  [nxt}  to  recover  the  graphics  menu. 

Next,  we  will  find  the  intersection  of  the  curve  with  the  x-axis  by  pressing 
liSH  ESE£i.  The  calculator  returns  the  value  Root :  l,  confirming  that  ln(T)  =  0. 
Press  (W)(W)||iE5i3  EEHS  to  return  to  the  PLOT  WINDOW  -  FUNCTION. 
Press  (mh)  to  return  to  normal  calculgtor  displgy.  You  will  notice  that  the  root 
found  in  the  graphics  environment  was  copied  to  the  calculator  stack. 
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Note:  When  you  press  tj^iJ  ,  your  variables  list  will  show  new  variables 
called  lllilillil    and  .     Press  to  see  the  contents  of  this 

variable.  You  will  get  the  program  «  ^  X  'LN(X)'  »  ,  which  you  will 
recognize  as  the  program  that  may  result  from  defining  the  function  'Yl  (X)  = 
LN(X)'  by  using  (JiD?^  •  This  is  basically  what  happens  when  you  IIIMi]!!  a 
function  in  the  PLOT  -  FUNCTION  window  (the  window  that  results  from 
pressing  <n  J=^,  simultaneously  if  in  RPN  mode),  i.e.,  the  function  gets 
defined  and  added  to  your  variable  list. 

Next,  press  (.  r»  Jiiliil  to  see  the  contents  of  this  variable.  A  value  of  1 0.275  is 
placed  in  the  stack.  This  value  is  determined  by  our  selection  for  the 
horizontal  display  range.  We  selected  a  range  between  -1  and  10  for  X.  To 
produce  the  graph,  the  calculator  generates  values  between  the  range  limits 
using  a  constant  increment,  and  storing  the  values  generated,  one  at  a  time, 
in  the  variable  nSSSS  as  the  graph  is  drawn.  For  the  horizontal  range  (  -1,10), 
the  increment  used  seems  to  be  0.275.  When  the  value  of  X  becomes  larger 
than  the  maximum  value  in  the  range  (in  this  case,  when  X  =  10.275),  the 
drawing  of  the  graph  stops.  The  last  value  of  X  for  the  graphic  under 
consideration  is  kept  in  variable  X.    Delete  X  and  Yl  before  continuing. 


Graph  of  the  exponential  function 

First,  load  the  function  exp(X),  by  pressing,  simultaneously  if  in  RPN  mode,  the 
left-shift  key  ED  and  the  Jt^  (C^)  key  to  access  the  PLOT-FUNCTION 
window.    Press  E3M  to  remove  the  function  LN(X),  if  you  didn't  delete  Yl  as 

suggested  in  the  previous  note.  Press  ;"°""r'°"  and  type  [Jjjfl  [AWHA){x](ENm}  to 

enter  EXP(X)  and  return  to  the  PLOT-FUNCTION  window.  Press  (W]SS3II1  to 
return  to  normal  calculator  display. 

Next,  press,  simultaneously  if  in  RPN  mode,  the  left-shift  key  (.  *i  J  and  the 
JMVL  (GD)  key  to  produce  the  PLOT  WINDOW  -  FUNCTION  window. 
Change  the  H-View  values  to  read:  H-View:  -8  2 

by  using  [  g  Jl  +/-  J BaM|~2~] B3M.  Next,  press  ylilliiji^l.  After  the  vertical  range 
is  calculated,  press  S^33§jSII3T!II  to  plot  the  exponential  function. 
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To  add  labels  to  the  graph  press  """■"[woj ri"".  Press  ICHIE  to  remove  the 
menu  labels,  and  get  a  full  view  of  the  graph.  Press  [nxt ]Inxt }^^Ms  yiSiiillsH  to 
return  to  the  PLOT  WINDOW  -  FUNCTION.  Press  to  return  to  normal 
calculator  display. 

The  PPAR  variable 

Press  [  VAR  J  to  recover  your  variables  menu,  if  needed.  In  your  variables  menu 
you  should  have  a  variable  labeled  PPAR  .  Press  L  r>  jBZSB  to  get  the 
contents  of  this  variable  in  the  stack.  Press  the  dov/n-arrov/  key,  ,  to  launch 
the  stack  editor,  and  use  the  up-  and  down-arrow  keys  to  view  the  full  contents 
of  PPAR.  The  screen  will  show  the  following  values: 


H-S.,-1. 107972632S1) & 
RPL>  a 

t-S.  ,-1.  107972632Sn 
(.2.  ,7.3S905609S93>  X 
a.    t0. ,0. >  FUNCTION  Y 


+^KIP|SKIP-H  H)EL  I  DEL-f|DEL  L|  inS  ■ 


PPAR  stands  for  Plot  PARameters,  and  its  contents  include  two  ordered  pairs  of 
real  numbers,  (-8.,-!  .10797263281)  and  (2.,7.38905609893), 

which  represent  the  coordinates  of  the  lower  left  corner  and  the  upper  right 
corner  of  the  plot,  respectively.  Next,  PPAR  lists  the  name  of  the  independent 
variable,  X,  followed  by  a  number  that  specifies  the  increment  of  the 
independent  variable  in  the  generation  of  the  plot.  The  value  shown  here  is 
the  default  value,  zero  (0.),  which  specifies  increments  in  X  corresponding  to 
1  pixel  in  the  graphics  display.  The  next  element  in  PPAR  is  a  list  containing 
first  the  coordinates  of  the  point  of  intersection  of  the  plot  axes,  i.e.,  (0.,0.), 
followed  by  a  list  that  specifies  the  tick  mark  annotation  on  the  x-  and  y-axes, 
respectively  {#  lOd  #  lOd}.  Next,  PPAR  lists  the  type  of  plot  that  is  to  be 
generated,  i.e.,  FUNCTION,  and,  finally,  the  y-axis  label,  i.e.,  Y. 

The  variable  PPAR,  if  non-existent,  is  generated  every  time  you  create  a  plot. 
The  contents  of  the  function  will  change  depending  on  the  type  of  plot  and  on 
the  options  that  you  select  in  the  PLOT  window  (the  window  generated  by  the 
simultaneous  activation  of  the  I  <~i  J  and  jw,  (GD  )  keys. 
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Inverse  functions  and  their  graphs 

Let  y  =  f(x),  if  we  can  find  a  function  y  =  g(x),  such  that,  g(f(x))  =  x,  then  we 
soy  that  g(x)  is  the  inverse  function  of  f(x).  Typically,  the  notation  g(x)  =  f  ^(x) 
is  used  to  denote  an  inverse  function.  Using  this  notation  we  can  write:  if  y  = 
f(x),  then  X  =  f  '(yj.   Also,  f(f  '(x))  =  x,  and  f  -'(f(x))  =  x. 

As  indicated  earlier,  the  ln(x)  and  exp(x)  functions  are  inverse  of  each  other, 
i.e.,  In(exp(x))  =  x,  and  exp(ln(x))  =  x.  This  can  be  verified  in  the  calculator 
by  typing  and  evaluating  the  following  expressions  in  the  Equation  Writer: 
LN(EXP(X))  and  EXP(LN(X)).  They  should  both  evaluate  to  X. 

When  a  function  f(x)  and  its  inverse  f  '^(x)  are  plotted  simultaneously  in  the 
same  set  of  axes,  their  graphs  are  reflections  of  each  other  about  the  line  y  = 
x.  Let's  check  this  fact  with  the  calculator  for  the  functions  LN(X)  and  EXP(X) 
by  following  this  procedure: 

Press,  simultaneously  if  in  RPN  mode,  C2D^.  The  function  Y1(X)  =  EXP(X) 
should  be  available  in  the  PLOT  -  FUNCTION  window  from  the  previous 
exercise.  Press  ,  and  type  the  function  VS^Xy  ==I...NfH/.  Also,  load 

the  function  Y3(X)  =  X.  Press  [A/xrj8Ea8  to  return  to  normal  calculator  display. 

Press,  simultaneously  if  in  RPN  mode,  LJiJ ,  and  change  the  H-View 
range  to  read:  H-View:  -8  8 

Press  lljiLlliyj  to  generate  the  vertical  range.  Press  iLilMo  [iliilili  to  produce  the 
graph  of  y  =  in(x),  y  =  exp(x),  and  y  =x,  simultaneously  if  in  RPN  mode. 

You  will  notice  that  only  the  graph  of  y  =  exp(x)  is  clearly  visible.  Something 
went  wrong  with  the  CUDEI  selection  of  the  vertical  range.  What  happens  is 
that,  when  you  press  illEij  in  the  PLOT  FUNCTION  -  WINDOW  screen,  the 
calculator  produces  the  vertical  range  corresponding  to  the  first  function  in  the 
list  of  functions  to  be  plotted.  Which,  in  this  case,  happens  to  be  Y1(X)  = 
EXP(X).  We  will  have  to  enter  the  vertical  range  ourselves  in  order  to  display 
the  other  two  functions  in  the  same  plot. 
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Press  to  return  to  the  PLOT  FUNCTION  -  WINDOW  screen.  Modify 

the  vertical  and  horizontal  ranges  to  read:  H-View:  -8       8,  V-View:  -4  4 

By  selecting  these  ranges  we  ensure  that  the  scale  of  the  graph  is  kept  1 
vertical  to  1  horizontal.  Press  IHIiijilO IIMl □  and  you  will  get  the  plots  of  the 
natural  logarithm,  exponential,  and  y  =  x  functions.  It  will  be  evident  from  the 
graph  that  LN(X)  and  EXP(X)  are  reflections  of  each  other  about  the  line  y  =  X. 
Press  =■= =■=■  to  return  to  the  PLOT  WINDOW  -  FUNCTION.  Press  to 
return  to  normal  calculator  display. 

Summary  of  FUNCTION  plot  operation 

In  this  section  we  present  information  regarding  the  PLOT  SETUP,  PLOT- 
FUNCTION,  and  PLOT  WINDOW  screens  accessible  through  the  left-shift  key 
combined  with  the  soft-menu  keys  QT]  through  CfT] .  Based  on  the  graphing 
examples  presented  above,  the  procedure  to  follow  to  produce  a  FUNCTION 
plot  (i.e.,  one  that  plots  one  or  more  functions  of  the  form  Y  =  F(X)),  is  the 
following: 

(JnJjrajD  ,  simultaneously  if  in  RPN  mode:  Access  to  the  PLOT  SETUP  window. 
If  needed,  change  type  to  function,  and  enter  the  name  of  the  independent 
variable. 
Setfinqs: 

•  A  check  on  _simuit  means  that  if  you  have  two  or  more  plots  in  the 
same  graph,  they  will  be  plotted  simultaneously  when  producing  the 
graph. 

•  A  check  on  _connect  means  that  the  curve  will  be  a  continuous  curve 
rather  than  a  set  of  individual  points. 

•  A  check  on  Pixels  means  that  the  marks  indicated  by  H-Tick  and  v- 
Tick  will  be  separated  by  that  many  pixels. 

•  The  default  value  for  both  by  H-Tick  and  v-Tick  is  1 0. 
Soft  key  menu  options: 

•  Use  0111!  to  edit  functions  of  values  in  the  selected  field. 

•  Use  mLS^I  to  select  the  type  of  plot  to  use  when  the  Type :  field  is 
highlighted.  For  the  current  exercises,  we  want  this  field  set  to 
FUNCTION. 
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Note:  the  soft  menu  keys  OljlijI  and  iSIEl!?  ore  not  available  at  the  same 
time.  One  or  the  other  will  be  selected  depending  on  which  input  field  is 
highlighted. 


•  Press  the  AXES  soft  menu  key  to  select  or  deselect  the  plotting  of  axes  in 
the  graph.  If  the  option  'plot  axes'  is  selected,  a  square  dot  will  appear 
in  the  key  label:  [illSisH  .  Absence  of  the  square  dot  indicates  that  axes 
will  not  be  plotted  in  the  graph. 

•  Use  IliliiE  to  erase  any  graph  currently  existing  in  the  graphics  display 
window. 

•  Use  Eu33II  to  produce  the  graph  according  to  the  current  contents  of  PPAR 
for  the  equations  listed  in  the  PLOT-FUNCTION  window. 

•  Press  [nxF)  to  access  the  second  set  of  soft  menu  keys  in  this  screen. 

•  Use  lilaiiiy  to  reset  any  selected  field  to  its  default  value. 

•  Use  EEEEia  to  cancel  any  changes  to  the  PLOT  SETUP  window  and  return 
to  normal  calculator  display. 

•  Press  lilililljli  to  save  changes  to  the  options  in  the  PLOT  SETUP  window  and 
return  to  normal  calculator  display. 

UxJ,J^  /  simultaneously  if  in  RPN  mode:  .  Access  to  the  PLOT  window  (in 
this  case  it  will  be  called  PLOT  -FUNCTION  window). 

Soft  menu  key  options: 

•  Use  HHi  to  edit  the  highlighted  equation. 

•  Use  HIjEEII  to  add  new  equations  to  the  plot. 

Note:  UliEEIII  or  Uilii  will  trigger  the  equation  writer  EQW  that  you  can 
use  to  write  new  equations  or  edit  old  equations. 

•  Use "'i'"  to  remove  the  highlighted  equation. 

•  Use  IHIELjlEI  to  add  an  equation  that  is  already  defined  in  your  variables 
menu,  but  not  listed  in  the  PLOT  -  FUNCTION  window. 

•  Use  EfliElil  to  erase  any  graph  currently  existing  in  the  graphics  display 
window. 

•  Use  liSiliill  to  produce  the  graph  according  to  the  current  contents  of  PPAR 
for  the  equations  listed  in  the  PLOT-FUNCTION  window. 

•  Press  Lw^rj  to  activate  the  second  menu  list. 
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•  Use  ri:!:!!"!"!!"  and  luliH-jl!  to  move  the  selected  equation  one  location  up  or 
down,  respectively. 

•  Use  B1333  if  you  want  to  clear  all  the  equations  currently  active  in  the 
PLOT  -  FUNCTION  window.  The  calculator  will  verify  whether  or  not 
you  want  to  clear  all  the  functions  before  erasing  all  of  them.  Select  YES, 
and  press  tESBi  to  proceed  with  clearing  all  functions.  Select  NO,  and 
press  SEUSI  to  de-activate  the  option  CLEAR. 

•  Press  SEIoSn  when  done  to  return  to  normal  calculator  display. 

CfDJ^*L,  simultaneously  if  in  RPN  mode:  Access  to  the  PLOT  WINDOW 
screen. 

Seffings: 

•  Enter  lower  and  upper  limits  for  horizontal  view  (H-View)  and  vertical 
view  (V-View)  ranges  in  the  plot  window.  Or, 

•  Enter  lower  and  upper  limits  for  horizontal  view  (H-View),  and  press  EmIIm, 
while  the  cursor  is  in  one  of  the  V-View  fields,  to  generate  the  vertical 
view  (V-View)  range  automatically.  Or, 

•  Enter  lower  and  upper  limits  for  vertical  view  (V-View),  and  press  'ITiiT:, 
while  the  cursor  is  in  one  of  the  H-View  fields,  to  generate  the  horizontal 
view  (H-View)  range  automatically. 

•  The  calculator  will  use  the  horizontal  view  (H-View)  range  to  generate 
data  values  for  the  graph,  unless  you  change  the  options  Indep  Low, 
(Indep)  High,  and  (Indep)  Step.  These  values  determine,  respectively,  the 
minimum,  maximum,  and  increment  values  of  the  independent  variable  to 
be  used  in  the  plot.  If  the  option  Default  is  listed  in  the  fields  Indep  Low, 
(Indep)  High,  and  (Indep)  Step,  the  calculator  will  use  the  minimum  and 
maximum  values  determined  by  H-View. 

•  A  check  on  _Pixels  means  that  the  values  of  the  independent  variable 
increments  (Step:)  are  given  in  pixels  rather  than  in  plot  coordinates. 

Soft  menu  key  options: 

•  Use  0111!  to  edit  any  entry  in  the  window. 

•  Use  EISS  as  explained  in  Settings,  above. 
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.  Use  oMIjil  to  erase  any  graph  currently  existing  in  the  graphics  display 
window. 

•  Use  E33I]  to  produce  the  graph  according  to  the  current  contents  of  PPAR 
for  the  equations  listed  in  the  PLOT-FUNCTION  window. 

•  Press  [nxtJ  to  activate  the  second  menu  list. 

•  Use  IGiiEy!!i!y  to  reset  the  field  selected  (i.e.,  where  the  cursor  is  positioned) 
to  its  default  value. 

•  Use  Bj™3  to  access  calculator  stack  to  perform  calculations  that  may  be 
necessary  to  obtain  a  value  for  one  of  the  options  in  this  window.  When 
the  calculator  stack  is  made  available  to  you,  you  will  also  have  the  soft 
menu  key  options  SSSas  and  SS3SS!  . 

•  Use  IffinH!!  in  case  you  want  to  cancel  the  current  calculation  and  return  to 
the  PLOT  WINDOW  screen.  Or, 

•  Use  SS3SI!  to  accept  the  results  of  your  calculation  and  return  to  the  PLOT 
WINDOW  screen. 

•  Use  to  get  information  on  the  type  of  objects  that  can  be  used  in 
the  selected  option  field. 

•  Use  SSuas  to  cancel  any  changes  to  the  PLOT  WINDOW  screen  and 
return  to  normal  calculator  display. 

•  Press  1 !:.::  to  accept  changes  to  the  PLOT  WINDOW  screen  and  return 
to  normal  calculator  display. 

(I^tJ GRAPH  ^  simultaneously  if  in  RPN  mode:  Plots  the  graph  based  on  the 
settings  stored  in  variable  PPAR  and  the  current  functions  defined  in  the 
PLOT  -  FUNCTION  screen.  If  a  graph,  different  from  the  one  you  are  plotting, 
already  exists  in  the  graphic  display  screen,  the  new  plot  will  be 
superimposed  on  the  existing  plot.  This  may  not  be  the  result  you  desire, 
therefore,  I  recommend  to  use  the  IDiiiiiO  liiiiiili  soft  menu  keys  available  in  the 
PLOT  SETUP,  PLOT-FUNCTION  or  PLOT  WINDOW  screens. 

Plots  of  trigonometric  and  hyperbolic  functions 

The  procedures  used  above  to  plot  LN(X)  and  EXP(X),  separately  or 
simultaneously,  can  be  used  to  plot  any  function  of  the  form  y  =  f(x).  It  is  left 
as  an  exercise  to  the  reader  to  produce  the  plots  of  trigonometric  and 
hyperbolic  functions  and  their  inverses.  The  table  below  suggests  the  values 
to  use  for  the  vertical  and  horizontal  ranges  in  each  case.  You  can  include 
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the  function  Y=X  when  plotting  simultaneously  a  function  and  its  inverse  to 
verify  their  'reflection'  about  the  line  Y  =  X. 


H-Viev/  range 

V-Viev/  range 

Function 

Minimum 

Maximum 

Minimum 

Maximum 

SIN(X) 

-3.15 

3.15 

AUTO 

ASIN(X) 

-1.2 

1.2 

AUTO 

SIN  &  ASIN 

-3.2 

3.2 

-1.6 

1.6 

COS(X) 

-3.15 

3.15 

AUTO 

ACOS(X) 

-1.2 

1.2 

AUTO 

COS  &  ACQS 

-3.2 

3.2 

-1.6 

1.6 

TAN(X) 

-3.15 

3.15 

-10 

10 

ATAN(X) 

-10 

10 

-1.8 

1.8 

TAN  &  ATAN 

-2 

-2 

-2 

-2 

SINH(X) 

-2 

2 

AUTO 

ASINH(X) 

-5 

5 

AUTO 

SINH  &ASINH 

-5 

5 

-5 

5 

COSH(X) 

-2 

2 

AUTO 

ACOSH(X) 

-1 

5 

AUTO 

COS  &  ACOS 

-5 

5 

-1 

5 

TANH(X) 

-5 

5 

AUTO 

ATANH(X) 

-1.2 

1.2 

AUTO 

TAN  &  ATAN 

-5 

5 

-2.5 

2.5 

Generating  a  table  of  values  for  a  function 

The  combinations  [JiJJSM.  [CBD  )  and  [JiJ3^  {(JL) ),  pressed  simultaneously 
if  in  RPN  mode,  let's  the  user  produce  a  table  of  values  of  functions.  For 
example,  v/e  will  produce  a  table  of  the  function  Y(X)  =  X/(X-i-10),  in  the 
range  -5  <  X  <  5  following  these  instructions: 

•  We  will  generate  values  of  the  function  f(x),  defined  above,  for  values  of 
X  from  -5  to  5,  in  increments  of  0.5.  First,  we  need  to  ensure  that  the 
graph  type  is  set  to  FUNCTION  in  the  PLOT  SETUP  screen  ((jTDiMo  ,  press 
them  simultaneously,  if  in  RPN  mode).  The  field  in  front  of  the  Type  option 
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will  be  highlighted.  If  this  field  is  not  already  set  to  FUNCTION,  press  the 
soft  key  iyii^^j^i  and  select  the  FUNCTION  option,  then  press  BLfl. 

•  Next,  press  to  highlight  the  field  in  front  of  the  option  EQ,  and  type 
the  function  expression:  'X/(X+10)' 

•  To  accept  the  changes  made  to  the  PLOT  SETUP  screen  press  [hxt]  SII3II. 
You  will  be  returned  to  normal  calculator  display. 

•  The  next  step  is  to  access  the  Table  Set-up  screen  by  using  the  keystroke 
combinationC5D!MI  (i.e.,  soft  key  )  -  simultaneously  if  in  RPN  mode. 
This  will  produce  a  screen  where  you  can  select  the  starting  value  (Start) 
and  the  increment  (Step).  Enter  the  following:  I  5  J[  J  B331 
[  0  J[  •  J[  5  J  LOJ L_lJ UJ  iii^Jiii (i.e..  Zoom  factor  =  0.5).  Toggle 
the  soft  menu  key  until  a  check  mark  appears  in  front  of  the  option 
Small  Font  if  you  so  desire.  Then  press  SSHIII.  This  will  return  you  to 
normal  calculator  display. 

The  TPAR  variable 


After  finishing  the  table  set  up,  your  calculator  will  create  a  variable  called 
TPAR  (Table  PARameters)  that  store  information  relevant  to  the  table  that  is  to 
be  generated.  To  see  the  contents  of  this  variable,  press  I  r»  J £5133. 


•  To  see  the  table,  press  C3lDi?^  (i.e.,  soft  menu  key  (j^  )  -  simultaneously 
if  in  RPN  mode.  This  will  produce  a  table  of  values  of  x  =  -5,  -4.5, 
and  the  corresponding  values  of  f(x),  listed  as  Yl  by  default.  You  can  use 
the  up  and  down  arrow  keys  to  move  about  in  the  table.  You  will  notice 
that  we  did  not  have  to  indicate  an  ending  value  for  the  independent 
variable  x.  Thus,  the  table  continues  beyond  the  maximum  value  for  x 
suggested  early,  namely  x  =  5. 

Some  options  available  while  the  table  is  visible  are  I^ISHI,  vSj^,  and  EHIII]: 

•  The  ESII,  when  selected,  shows  the  definition  of  the  independent  variable. 

•  The  IS3I3I  key  simply  changes  the  font  in  the  table  from  small  to  big,  and 
vice  versa.  Try  it. 
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•    The  lEiEljllil  key,  when  pressed,  produces  a  menu  with  the  options:  In,  Out, 
Decimal,  Integer,  and  Trig.  Try  the  following  exercises: 


•  With  the  option  In  highlighted,  press  The  table  is  expanded  so 
that  the  x-increment  is  now  0.25  rather  than  0.5.  Simply,  what  the 
calculator  does  is  to  multiply  the  original  increment,  0.5,  by  the  zoom 
factor,  0.5,  to  produce  the  new  increment  of  0.25.  Thus,  the  zoom  in 
option  is  useful  when  you  want  more  resolution  for  the  values  of  x  in 
your  table. 

•  To  increase  the  resolution  by  an  additional  factor  of  0.5  press  BSUU, 
select  In  once  more,  and  press  SEI3SI.  The  x-increment  is  now  0.01 25. 

•  To  recover  the  previous  x-increment,  press  !'::':"!!"!'      IIIIIMIl  to  select 
the  option  Un-zoom.  The  x-increment  is  increased  to  0.25. 

•  To  recover  the  original  x-increment  of  0.5  you  can  do  an  un-zoom 
again,  or  use  the  option  zoom  out  by  pressing  l§^l  iiSSil. 

•  The  option  Decimal  in  !!':!7.:.:  produces  x-increments  of  0.10. 

•  The  option  Integer  in  isiiiiu  produces  x-increments  of  1 . 

•  The  option  Trig  in  produces  increments  related  to  fractions  of  ^,  thus 
being  useful  when  plotting  trigonometric  functions. 

•  To  return  to  normal  calculator  display  press  . 

Plots  in  polar  coordinates 

First  of  all,  you  may  want  to  delete  the  variables  used  in  previous  examples 
(e.g.,  X,  EQ,  Yl,  PPAR)  using  function  PURGE  ((roa)  mm).  By  doing  this,  all 
parameters  related  to  graphics  will  be  cleared.  Press  I  w/;  J  to  check  that  the 
variables  were  indeed  purged. 

We  will  try  to  plot  the  function  f(9)  =  2(l-sin(9)),  as  follows: 

•  First,  make  sure  that  your  calculator's  angle  measure  is  set  to  radians. 

•  Press  (JjJJSMl,  simultaneously  if  in  RPN  mode,  to  access  to  the  PLOT 
SETUP  window. 

•  Change  type  to  Polar,  by  pressing  SSSua  IIuIIIh. 

•  Press       and  type: 


Page  12-19 


•  The  cursor  is  now  in  the  indep  field.  Press  QD(4^^C5D(3  B338S  to 
change  the  independent  variable  to  6. 

•  Press  (jwLlSEy^  to  return  to  normal  calculator  display. 

•  Press  LjnJ  J5*L ,  simultaneously  if  in  RPN  mode,  to  access  the  PLOT 
window  (in  this  case  it  will  be  called  PLOT  -POLAR  window). 

•  Change     the     H-VIEW     range     to     -8     to     8,     by  using 
CZDC^BaSSODKIaB,  and  the  V-VIEW  range  to  -6  to  2  by  using 

dJ      iiililiiCX]  iliii^ilii  ■  

Note:  the  H-VIEW  and  V-VIEW  determine  the  scales  of  the  display 
window  only,  and  their  ranges  are  not  related  to  the  range  of  values 
of  the  independent  variable  in  this  case. 

•  Change  the  indep  Low  value  to  0,  and  the  High  value  to  6.28  («  271),  by 
using:  CZD13Ilii  CiDCZDCiDClDiCiiJil. 

•  Press  eEEbLsI  yjiiiilli  to  plot  the  function  in  polar  coordinates.  The  result  is  a 
curve  shaped  like  a  hearth.  This  curve  is  known  as  a  cardiod  (cardios, 
Greek  for  heart). 
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•  Press  IMSilnxT]  yjjjjjiijijjiiLiiiijE  to  see  the  graph  with  labels.  Press  [nxt]  to 
recover  the  menu.  Press  [nxt)  iSiSi  to  recover  the  original  graphics  menu. 

•  Press  'I'::'::":'::'::  7°°™:'  to  trace  the  curve.  The  data  shown  at  the  bottom  of 
the  display  is  the  angle  0  and  the  radius  r,  although  the  latter  is  labeled  Y 
(default  name  of  dependent  variable). 

•  Press  (WlEEIIES  to  return  to  the  PLOT  WINDOW  screen.  Press  {mTitEM 
to  return  to  normal  calculator  display. 

In  this  exercise  we  entered  the  equation  to  be  plotted  directly  in  the  PLOT 
SETUP  window.  We  can  also  enter  equations  for  plotting  using  the  PLOT 
window,  i.e.,  simultaneously  if  in  RPN  mode,  pressing  [Jjjjt^ .  For 
example,  when  you  press  (JxJ.J=-.    after  finishing  the  previous  exercise,  you 
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will  get  the  equation  '2*(1 -SINfB))'  highlighted.  Let's  say,  we  want  to  plot 
also  the  function  '2*(l-COS(9))'  along  with  the  previous  equation. 


•  Press  SuIiEB  ,  and  type  CX)CEDC5D(^  CZDCED  CW)(^CED(S(^,  to 
enter  the  new  equation. 

•  Press  IGajEliia  iSaill]  to  see  the  two  equations  plotted  in  the  same  figure.  The 
result  is  two  intersecting  cardioids.  Press  laSIHa  L  on  J  to  return  to  normal 
calculator  display.   ^  
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Plotting  conic  curves 

The  most  general  form  of  a  conic  curve  in  the  x-y  plane  is: 
Ax^+By^+Cxy+Dx+Ey+F  =  0.  We  also  recognize  as  conic  equations  those 
given  in  the  canonical  form  for  the  following  figures: 


•  circle: 

•  ellipse: 


parabola: 
hyperbola: 


(x-xf+(y-yf  =  r2 

(x-xjVa^  +  (y-yo)Vb2=  1 
(y-b)2  =  K(x-a)  or  (x-a)^  =  K(y-b) 
(x-x„)Va2  +  (y-yo)Vb2=  1  or  xy  =  K, 


where  x^,  y^/     'b/  cmd  K  are  constant. 


The  name  conic  curves  follows  because  these  figures  (circles,  ellipses, 
parabolas  or  hyperbolas)  result  from  the  intersection  of  a  plane  with  a  cone. 
For  example,  a  circle  is  the  intersection  of  a  cone  with  a  plane  perpendicular 
to  the  cone's  main  axis. 


The  calculator  has  the  ability  of  plotting  one  or  more  conic  curves  by  selecting 
Conic  as  the  function  TYPE  in  the  PLOT  environment.  Make  sure  to  delete  the 
variables  PPAR  and  EQ  before  continuing.  For  example,  let's  store  the  list  of 
equations 
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{ '(X-l)^2+(Y-2)^2=3' ,  'X'^2/4+Y'^2/3=l' } 


into  the  variable  EQ. 

These  equations  we  recognize  as  those  of  a  circle  centered  at  (1,2)  with 
radius  V3,  and  of  an  ellipse  centered  at  (0,0)  with  semi-axis  lengths  a  =  2  and 
b  =  V3. 

•  Enter  the  PLOT  environment,  by  pressing  (jnHiS?^,  simultaneously  if  in 
RPN  mode,  and  select  Conic  as  the  TYPE.  The  list  of  equations  will  be 
listed  in  the  EQ  field. 

•  Make  sure  that  the  independent  variable  (indep)  is  set  to  'X'  and  the 
dependent  variable  (Depnd)  to  'Y'. 

•  Press  ['VAT  J  ESI  to  return  to  normal  calculator  display. 

•  Enter  the  PLOT  WINDOW  environment,  by  pressing  (_<nj  ^ 
simultaneously  if  in  RPN  mode. 

•  Change  the  range  for  H-VIEW  to  -3  to  3,  by  using 
CTDraiSEIIilCTDSSElIS!.  Also,  change  the  V-VIEW  range  to  -1 .5  to  2  by 
using  QJ CD CSCZDIi":.::::  ^ 

•  Change  the  Indep  Low:  and  High:  fields  to  Default  by  using  (nxtJ  IlilSHs 
while  each  of  those  fields  is  highlighted.  Select  the  option  Reset  value 
after  pressing  BlaSH.  Press  ISEIISto  complete  the  resetting  of  values. 
Press  [nxtJ  to  return  to  the  main  menu. 

•  riot  the  grapri:  ui]ij::9j  U111J.J. 


V  1 

ZOOM  |(K^V) 

1         1  1 
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Note:  The  H-view  and  v-view  ranges  were  selected  to  show  the  intersection 
of  the  two  curves.  There  is  no  general  rule  to  select  those  ranges,  except 
based  on  what  we  know  about  the  curves.  For  example,  for  the  equations 
shown  above,  we  know  that  the  circle  will  extend  from  -3+1  =  -2  to  3-1-1  =4 
in  X,  and  from  -3-i-2=-l  to  3-1-2=5  in  y.    In  addition,  the  ellipse,  which  is 
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centered  at  the  origin  (0,0),  will  extend  from  -2  to  2  in  x,  and  from  -V3  to  V3 
in  y. 

Notice  that  for  the  circle  and  the  ellipse  the  region  corresponding  to  the  left 
and  right  extremes  of  the  curves  are  not  plotted.  This  is  the  case  with  all 
circles  or  ellipses  plotted  using  Conic  as  the  type. 


To  see  labels:  UJSSi  (nxtJ  ' ' '  '_Z  Zl  [■'[" 
To  recover  the  menu:  ij^iNxrjMMi 

To  estimate  the  coordinates  of  the  point  of  intersection,  press  the  l{:3lli)ll 
menu  key  and  move  the  cursor  as  close  as  possible  to  those  points  using 
the  arrow  keys.  The  coordinates  of  the  cursor  are  shown  in  the  display. 
For  example,  the  left  point  of  intersection  is  close  to  (-0.692,  1 .67),  while 
the  right  intersection  is  near  (1 .89,0.5). 


V  1 

^:-s.saE-i 

V:1.S?ED 

V  1 

V:  .5 

•  To  recover  the  menu  and  return  to  the  PLOT  environment,  press  twrjiaSIiaj. 

•  To  return  to  normal  calculator  display,  press  (.wrjiBBSS. 


Parametric  plots 

Parametric  plots  in  the  plane  are  those  plots  whose  coordinates  are  generated 
through  the  system  of  equations  x  =  x(t)  and  y  =  y(t),  where  t  is  known  as  the 
parameter.  An  example  of  such  graph  is  the  trajectory  of  a  projectile,  x(t)  = 
Xq  +  Vq-COS  9o-t,  y(t)  =  yo  +  Vg-sin  9o-t  -  V2-g-f.  To  plot  equations  like  these, 
which  involve  constant  values  Xq,  yo,  Vq,  and  Bq,  we  need  to  store  the  values  of 
those  parameters  in  variables.  To  develop  this  example,  create  a  sub- 
directory called  'PROJM'  for  PROJectile  Motion,  and  within  that  sub-directory 
store  the  following  variables:  XO  =  0,  YO  =  1 0,  VO  =  1 0  ,  60  =  30,  and  g  = 
9.806.  Make  sure  that  the  calculator's  angle  measure  is  set  to  DEC  Next, 
define  the  functions  (use  I  *i  Jfff  ): 
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x(t)  =  xo  +  vo*cos(eo)*t 

Y(t)  =  YO  +  VO*SIN(eO)*t  -  0.5*g 


which  will  add  the  variables  SSSSI  and 


: 10frY0 

: 10frV0 

:30^e0 

:9.S06^^ 

:DEFIHE( 

^X(t)=X0+V0.COS(e> 

HOVRL 

*„*|A2 

to  the  soft  menu  key  labels. 


30fre0 

DEF I  HE?X(t  )=X0+V0-COS(eH 


DEFIHEl  Ya)=Y0+V0-SIH(e> 
HOVRL 
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To  produce  the  graph  itself,  follow  these  steps: 

•  Press  [Jjjj£lii.,  simultaneously  if  in  RPN  mode,  to  access  to  the  PLOT 
SETUP  window. 

•  Change  type  to  Parametric,  by  pressing  naluEfil  "sj? "sj? KiaB. 

•  Press  ^  and  type  'X(t)  +  i*Y(t)'  SUll  to  define  the  parametric  plot  as 
that  of  a  complex  variable.  (The  real  and  imaginary  parts  of  the  complex 
variable  correspond  to  the  x-  and  y-coordinates  of  the  curve.) 

•  The  cursor  is  now  in  the  indep  field.  Press  I  ■  }[alpha}C^(t]  SEIoh  to 
change  the  independent  variable  to  /. 

•  Press  [ft/xrjiiSjM  to  return  to  normal  calculator  display. 

•  Press  [JiJML,  simultaneously  if  in  RPN  mode,  to  access  the  PLOT 
window  (in  this  case  it  will  be  called  PLOT  -PARAMETRIC  window). 
Instead  of  modifying  the  horizontal  and  vertical  views  first,  as  done  for 
other  types  of  plot,  we  will  set  the  lower  and  upper  values  of  the 
independent  variable  first  as  follows: 

•  Select  the  indep  Low  field  by  pressing  '^P'^p .  Change  this  value  to 
LOJiiiillll.  Then,  change  the  value  of  High  to  (.  2  J  KM.  Enter  (.  0  JL  •  J 
[  /  Jilliyli  for  the  step  value  (i.e.,  step  =  0.1). 


Note:  Through  these  settings  we  are  indicating  that  the  parameter  t  will 
take  values  of  t  =  0,  0.1,  0.2,      etc.,  until  reaching  the  value  of  2.0. 


•  Press  !iEi33.  This  will  generate  automatic  values  of  the  H-View  and  V-View 
ranges  based  on  the  values  of  the  independent  variable  t  and  the 
definitions  of  X(t)  and  Y(t)  used.  The  result  will  be: 
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•  Press  HSSBHSiEj  to  draw  the  parametric  plot. 

•  Press  iniMMil [nxtJ  ImMS.  h3m  to  see  the  graph  with  labels.    The  window 
parameters  are  such  that  you  only  see  half  of  the  labels  in  the  x-axis. 


rV-~~ 
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17  isncnan?!;? 

•  Press  [nxT]  to  recover  the  menu.  Press  [a/atjEE^j  to  recover  the  original 
graphics  menu. 

•  Press  \SESi  .(::"::)  to  determine  coordinates  of  any  point  on  the  graph. 
Use  CD  and  (33  to  move  the  cursor  about  the  curve.  At  the  bottom  of  the 
screen  you  will  see  the  value  of  the  parameter  t  and  coordinates  of  the 
cursor  as  (X,Y). 

•  Press  (Nxfjmsm  to  return  to  the  PLOT  WINDOW  environment.  Then, 
press  C_owj  ,  or  [nxt] to  return  to  normal  calculator  display. 

A  review  of  your  soft  menu  key  labels  shows  that  you  now  have  the  following 
variables:  t,  EG,  PPAR,  Y,  X,  g,  60,  VO,  YO,  XO.  Variables  t,  EQ,  and  PPAR 
are  generated  by  the  calculator  to  store  the  current  values  of  the  parameter,  t, 
of  the  equation  to  be  plotted  EQ  (which  contains  'X(t)  +  l*Y(t)'),  and  the  plot 
parameters.  The  other  variables  contain  the  values  of  constants  used  in  the 
definitions  of  X(t)  and  Y(t). 

You  can  store  different  values  in  the  variables  and  produce  new  parametric 
plots  of  the  projectile  equations  used  in  this  example.  If  you  want  to  erase  the 
current  picture  contents  before  producing  a  new  plot,  you  need  to  access 
either  the  PLOT,  PLOT  WINDOW,  or  PLOT  SETUP  screens,  by  pressing, 
LtU^i^  ,  C5D  J!*L. ,  or  LtlJiQSD  (the  two  keys  must  be  pressed  simultaneously 
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if  in  RPN  mode).  Then,  press  II ■!! ililSI ■!!     ■!□   Press  IEIGImIIJI  to  return  to  the  PLOT, 
PLOT  WINDOW,  or  PLOT  SETUP  screen.    Press  C^,  or  CW3liSail,  to  return 
to  normal  calculator  display. 

Generating  a  table  for  parametric  equations 

In  an  earlier  example  we  generated  a  table  of  values  (X,Y)  for  an  expression 
of  the  form  Y=f(X),  i.e.,  a  Function  type  of  graph.    In  this  section,  we  present 
the  procedure  for  generating  a  table  corresponding  to  a  parametric  plot.  For 
this  purpose,  we'll  take  advantage  of  the  parametric  equations  defined  in  the 
example  above. 

•  First,  let's  access  the  TABLE  SETUP  window  by  pressing  Ijnjraun; , 
simultaneously  if  in  RPN  mode.  For  the  independent  variable  change 
the  Starting  value  to  0.0,  and  the  Step  value  to  0.1 .    Press  UliSSSi. 

•  Generate  the  table  by  pressing,  simultaneously  if  in  RPN  mode, 
(33  Mffif  .  The  resulting  table  has  three  columns  representing  the 
parameter  t,  and  the  coordinates  of  the  corresponding  points.  For 
this  table  the  coordinates  are  labeled  XI  and  Yl . 
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•  Use  the  arrow  keys,  CD  CT)      ^or? ,  to  move  about  the  table. 

•  Press  L  on  J  to  return  to  normal  calculator  display. 

This  procedure  for  creating  a  table  corresponding  to  the  current  type  of  plot 
can  be  applied  to  other  plot  types. 

Plotting  the  solution  to  simple  differential  equations 

The  plot  of  a  simple  differential  equation  can  be  obtained  by  selecting  Dif  f 
Eq  in  the  TYPE  field  of  the  PLOT  SETUP  environment  as  follows:  suppose  that 
we  want  to  plot  x(t)  from  the  differential  equotion  dx/dt  =  exp(-t^),  with  initial 
conditions:  x  =  0  at  t  =  0.  The  calculator  allows  for  the  plotting  of  the  solution 
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of  differential  equations  of  the  form  Y'(T)  =  F(T,Y).  For  our  case,  we  let  Y^x 
and  T^t,  tfierefore,  F(T,Y)^f(t,x)  =  expl-t^). 

Before  plotting  tfie  solution,  x(t),  for  t  =  0  to  5,  delete  the  variables  EQ  and 
PPAR. 

•  Press  C5Di^,  simultaneously  if  in  RPN  mode,  to  access  to  the  PLOT 
SETUP  window. 

•  Change  type  to  Diff  Eq. 

•  Press        and  type  (THPnl        C^l^^w]  pT] (t\  CTH CTl maS. 

•  The  cursor  is  now  in  the  H-var  field.  It  should  show  H-var :  0  and  also  v- 
Var:i.  This  is  the  code  used  by  the  calculator  to  identify  the  variables  to 
be  plotted.  H-var:0  means  the  independent  variable  (to  be  selected  later) 
will  be  plotted  in  the  horizontal  axis.       Also,  v-var:l  means  the 
dependent  variable  (default  name  'Y')  will  be  plotted  in  the  vertical  axis. 

•  Press  '^i?  .  The  cursor  is  now  in  the  indep  field.  Press  [  JL  ■  jjAum) 
UxJOiiEEii  to  change  the  independent  variable  to  t. 

•  Press  [A/xrjiSBSS  to  return  to  normal  calculator  display. 

•  Press  UnJ J»L ,  simultaneously  if  in  RPN  mode,  to  access  the  PLOT 
window  (in  this  case  it  will  be  called  PLOT  WINDOW  -  DIFF  EQ). 

•  Change  the  H-VIEW  and  V-VIEW  parameters  to  read:  H-VIEW:  -1  5, 
V-VIEW:  -1    1 .5 

•  Change  the  init  value  to  0,  and  the  Final  value  to  5  by  using:  L  0  jllEESB 
(.  5  jiailS. 

•  The  values  Step  and  Tol  represent  the  step  in  the  independent  variable 

and  the  tolerance  for  convergence  to  be  used  by  the  numerical  solution. 
Let's  leave  those  values  with  their  default  settings  (if  the  word  default  is 
not  shown  in  the  Step:  field,  use  {.nxt}  iEiiEiili  to  reset  that  value  to  its 
default  value.  Press  [nxtj  to  return  to  the  main  menu.)   Press  "sj?  . 

•  The  Init-Soln  value  represents  the  initial  value  of  the  solution  to  start  the 
numerical  result.  For  the  present  case,  we  have  for  initial  conditions  x(0) 
=  0,  thus,  we  need  to  change  this  value  to  0.0,  by  using  I  0  JiljIIIIiill. 

•  Press  SEIcu  EaE]  to  plot  the  solution  to  the  differential  equation. 

•  Press  SSi  (mr)  8333=13  ESu]]  to  see  the  graph  with  labels. 
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Press  [nxtJ  to  recover  the  menu.  Press  (.wxt-jEISIi  to  recover  the  original 
graphics  menu. 

When  we  observed  the  graph  being  plotted,  you'll  notice  that  the  graph 
is  not  very  smooth.  That  is  because  the  plotter  is  using  a  time  step  that  is 
too  large.  To  refine  the  graph  and  make  it  smoother,  use  a  step  of  0.1 . 
Try  the  follov^ing  keystrokes:  sillilililjll  "v^^^^t^I  •  JCTlEIiiijjTiiiiisyiiiilu. 
The  plot  will  take  longer  to  be  completed,  but  the  shape  is  definitely 
smoother  than  before. 

Press  _.:j.!=!.:!j  [nxtJ  |[!![in:i[!!l iZiilE  to  see  axes  labels  and  range.  Notice  that 
the  labels  for  the  axes  are  shown  as  0  (horizontal)  and  1  (vertical).  These 
are  the  definitions  for  the  axes  as  given  in  the  PLOT  WINDOW  screen 
(see  above),  i.e.,  H-VAR  (t):  0,  and  V-VAR(x):  1 . 
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•  Press  [j^InxtJ^^Mm  to  recover  menu  and  return  to  PICT  environment. 

•  Press  (wj)  to  determine  coordinates  of  any  point  on  the  graph.  Use 
CE5  and  (3D  to  move  the  cursor  in  the  plot  area.  At  the  bottom  of  the 
screen  you  will  see  the  coordinates  of  the  cursor  as  (X,Y).  The  calculator 
uses  X  and  Y  as  the  default  names  for  the  horizontal  and  vertical  axes, 
respectively. 

•  Press  [MJoJ ri:~:T!:T:  to  return  to  the  PLOT  WINDOW  environment.  Then, 
press  I  01^  J  to  return  to  normal  calculator  display. 

More  details  on  using  graphical  solutions  of  differential  equations  are 
presented  in  Chapter  16. 
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Truth  plots 

Truth  plots  are  used  to  produce  two-dimensional  plots  of  regions  that  satisfy  a 
certain  mathematical  condition  that  can  be  either  true  or  false.    For  example, 
suppose  that  you  want  to  plot  the  region  for  X'^2/36  +  ^^2/9  <  1 , 
proceed  as  follows: 

•  Press  UnJJMD  ^  simultaneously  if  in  RPN  mode,  to  access  to  the  PLOT 
SETUP  window. 

•  Change  TYPE  to  Truth. 

•  Press  ^  and  type  nX^2/36+Y"2/9  <  1  j^'fX'^ 2/1 6+^^2/9  >  1)'} 
iLiluli!  to  define  the  conditions  to  be  plotted. 

•  The  cursor  is  now  in  the  indep  field.   Leave  that  as  'X'  if  already  set  to 
that  variable,  or  change  it  to  'X'  if  needed. 

•  Press  (jwiJlllil!31lll  to  return  to  normal  calculator  display. 

•  Press  LJiJ      ,  simultaneously  if  in  RPN  mode,  to  access  the  PLOT 
window  (in  this  case  it  will  be  called  PLOT  WINDOW  -  TRUTH  window). 
Let's  keep  the  default  value  for  the  window's  ranges:  H-view:  -6.5  6.5, 
v-view :  -3 . 1    3 . 2  (To  reset  them  use  (W)  GSilS  (select  Reset  all) 


Note:  if  the  window's  ranges  are  not  set  to  default  values,  the  quickest  way 
to  reset  them  is  by  using  (W)E![SEi3  (select  Reset  all)  KlaSlwJ. 


•  Press  0!3jE[ii  iEEilC]  to  draw  the  truth  plot.  Because  the  calculator  samples 
the  entire  plotting  domain,  point  by  point,  it  takes  a  few  minutes  to 
produce  a  truth  plot.  The  present  plot  should  produce  a  shaded  ellipse  of 
semi-axes  6  and  3  (in  x  and  y,  respectively),  centered  at  the  origin. 

•  Press  EEHUCHiia  to  see  the  graph  with  labels.  The  window 
parameters  are  such  that  you  only  see  half  of  the  labels  in  the  x-axis. 
Press  [AWffJ  to  recover  the  menu.  Press  [/vxrJjjIEMi  to  recover  the  original 
graphics  menu. 

•  Press  (38ili)  to  determine  coordinates  of  any  point  on  the  graph.  Use  the 
arrow  keys  to  move  the  cursor  about  the  region  plotted.  At  the  bottom  of 
the  screen  you  will  see  the  value  of  the  coordinates  of  the  cursor  as  (X,Y). 

•  Press  (NXTjliilliTjjlij  to  return  to  the  PLOT  WINDOW  environment.  Then, 
press  I  ON  J  ,  or  [^r)SEI3B,  to  return  to  normal  calculator  display. 
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You  can  have  more  than  one  condition  plotted  at  the  same  time  if  you  multiply 
the  conditions.  For  example,  to  plot  the  graph  of  the  points  for  which  XV36 
+  YV9  <  1 ,  and  XVl  6  +  YV9  >  1 ,  use  the  following: 

•  Press  UnJi^o  ,  simultaneously  if  in  RPN  mode,  to  access  to  the  PLOT 
SETUP  window. 

•  Press  ^  and  type  '(X'^2/36+Y'^2/9  <  !)•  6+Y'^2/9  >  1)'KI3B 
to  define  the  conditions  to  be  plotted. 

•  Press  ll-ilj!IM:ill[i![i!Lij!!]  to  draw  the  truth  plot.  Again,  you  have  to  be  patient 
while  the  calculator  produces  the  graph.  If  you  want  to  interrupt  the  plot, 
press  I  ON  J  ,  once.  Then  press  HaSEIaiS  . 

Plotting  histograms,  bar  plots,  and  scatter  plots 

Histograms,  bar  plots  and  scatter  plots  are  used  to  plot  discrete  data  stored  in 
the  reserved  variable  SDAT.  This  variable  is  used  not  only  for  these  types  of 
plots,  but  also  for  all  kind  of  statistical  applications  as  will  be  shown  in 
Chapter  18.  As  a  matter  of  fact,  the  use  of  histogram  plots  is  postponed  until 
we  get  to  that  chapter,  for  the  plotting  of  a  histogram  requires  to  perform  a 
grouping  of  data  and  a  frequency  analysis  before  the  actual  plot.  In  this 
section  we  will  show  how  to  load  data  in  the  variable  EDAT  and  how  to  plot 
bar  plots  and  scatter  plots. 

We  will  use  the  following  data  for  plotting  bar  plots  and  scatter  plots: 


X       y  z 

3.1  2.1  1.1 
3.6    3.2  2.2 

4.2  4.5  3.3 
4.5  5.6  4.4 
4.9  3.8  5.5 
5.2    2.2  6.6 

Bar  plots 

First,  make  sure  your  calculator's  CAS  is  in  Exact  mode.  Next,  enter  the 
data  shown  above  as  a  matrix,  i.e.. 
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[[3.1,2.1,1.1],[3.6,3.2,2.2],[4.2,4.5,3.3], 
[4.5,5.6,4.4],[4.9,3. 8,5. 5],[5. 2,2. 2,6.6]]  S 

to  store  it  in  ZDAT,  use  the  function  STOZ  (available  in  the  function  catalog, 
[jfJ—CAj  ).  Press  VAR  to  recover  your  variables  menu.  A  soft  menu  key 
labeled  EDAT  should  be  available  in  the  stack.  The  figure  belov/  shows  the 
storage  of  this  matrix  in  ALG  mode: 


:ST02(RHS(1): 

4.2  4.5  3.3 
4.5  5.6  4.4 
4.9  3.  S  5.5 
,5.2  2.2  6.6, 

HOVRL 

EDHTICH^DII         1         1  1 

To  produce  the  graph: 

•  Press  IJnJio^ ,  simultaneously  if  in  RPN  mode,  to  access  to  the  PLOT 
SETUP  V(/indow. 

•  Change  type  to  Bar. 

•  A  matrix  will  be  shown  at  the  SDAT  field.  This  is  the  matrix  we  stored 
earlier  into  SDAT. 

•  Highlight  the  Col:  field.  This  field  lets  you  choose  the  column  of  EDAT 
that  is  to  be  plotted.  The  default  value  is  1 .  Keep  it  to  plot  column  1  in 
2DAT. 

•  Press  (j«iJlllll!31lli  to  return  to  normal  calculator  display. 

•  Press  UnJ JM, ,  simultaneously  if  in  RPN  mode,  to  access  the  PLOT 
WINDOW  screen. 

•  Change  the  V-View  to  read,  v-view:  0  5. 

•  Press  HSSB  EaiE]  to  draw  the  bar  plot. 
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•  Press  IClLMffl  to  return  to  the  PLOT  WINDOW  environment.   Then,  press 
[  ON  J  ,  or  C^r]||EEli,  to  return  to  normal  calculator  display. 

The  number  of  bars  to  be  plotted  determines  the  width  of  the  bar.  The  H-  and 
V-VIEW  are  set  to  1  0,  by  default.  We  changed  the  V-VIEW  to  better 
accommodate  the  maximum  value  in  column  1  of  SDAT.  Bar  plots  are  useful 
v/hen  plotting  categorical  (i.e.,  non-numerical)  data. 

Suppose  that  you  v/ant  to  plot  the  data  in  column  2  of  the  EDAT  matrix: 

•  Press  C5Di^,  simultaneously  if  in  RPN  mode,  to  access  to  the  PLOT 
SETUP  window. 

•  Press  '^^'^^   to  highlight  the  Col:  field  and  type  2  iiiyElili,  followed  by 
[NXTjmiLom. 

•  Press  [^JML,  simultaneously  if  in  RPN  mode,  to  access  to  the  PLOT 
SETUP  window. 

•  Change  V-View  to  read  v-view:  0  6 

•  rress  uoj^u  uaiLJ. 


•  Press  SSm  to  return  to  the  PLOT  WINDOW  screen,  then  (mJ  to  return 
to  normal  calculator  display. 

Scatter  plots 

We  will  use  the  same  EDAT  matrix  to  produce  scatter  plots.  First,  we  will  plot 
the  values  of  y  vs.  x,  then  those  of  y  vs.  z,  as  follows: 

•  Press  (JnJJMD  ,  simultaneously  if  in  RPN  mode,  to  access  to  the  PLOT 
SETUP  window. 

•  Change  type  to  Scatter. 
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•  Press  to  highlight  the  Cols:  field.  Enter  CDWIiiiil  CTDSEESS  to 
select  column  1  as  X  and  column  2  as  Y  in  the  Y-vs.-X  scatter  plot. 

•  Press  [wojISSSB  to  return  to  normal  calculator  display. 

•  Press  [jjJJM^,  simultaneously  if  in  RPN  mode,  to  access  the  PLOT 
WINDOW  screen. 

•  Change  the  plot  window  ranges  to  read:  H-View:  0  6,  V-Vlew:  0  6. 

•  Press  ia33aj  EEEu  to  draw  the  bar  plot.  Press  EiSm  (W)  E5iIS3  illilllll  to  see 
the  plot  unencumbered  by  the  menu  and  with  identifying  labels  (the  cursor 
will  be  in  the  middle  of  the  plot,  however): 


V 


•  Press  [nxt ]Inxt }MMs  to  leave  the  EDIT  environment. 

•  Press  EEIIIm  to  return  to  the  PLOT  WINDOW  environment.   Then,  press 
L  ON  J  ,  or  [NXTjSSS,  to  return  to  normal  calculator  display. 

To  plot  y  vs.  z,  use: 

•  Press  [jnDin^^,,  simultaneously  if  in  RPN  mode,  to  access  to  the  PLOT 
SETUP  window. 

•  Press  to  highlight  the  Cols :  field.  Enter  CZDBiBB  CTDISEEB  to 
select  column  3  as  X  and  column  2  as  Y  in  the  Y-vs.-X  scatter  plot. 

•  Press  (jwojOiLlli  to  return  to  normal  calculator  display. 

•  Press  CfDJ^;  simultaneously  if  in  RPN  mode,  to  access  the  PLOT 
WINDOW  screen. 

•  Change  the  plot  window  ranges  to  read:  H-View:  0  7,  V-View:  0  7. 

•  Press  yjiiii^o Liliiilli  to  draw  the  bar  plot.    Press  MMi [nxtJ  Puniyja lilallG  to  see 
the  plot  unencumbered  by  the  menu  and  with  identifying  labels. 

V 


y. 
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•  Press  {j^(N><TjmMs!  to  leave  the  EDIT  environment. 

•  Press  l^iiiiiiiS  to  return  to  the  PLOT  WINDOW  environment.    Then,  press 
I  ON  J  ,  or  LwxT-jIBIHB,  to  return  to  normal  calculator  display. 

Slope  fields 

Slope  fields  are  used  to  visualize  the  solutions  to  a  differential  equation  of  the 
form  y'  =  f(x,y).  Basically,  what  is  presented  in  the  plot  are  segments 
tangential  to  the  solution  curves,  since  y'  =  dy/dx,  evaluated  at  any  point  (x,y), 
represents  the  slope  of  the  tangent  line  at  point  (x,y). 

For  example,  to  visualize  the  solution  to  the  differential  equation  y'  =  f{x,y)  = 
x+y,  use  the  following: 

•  Press  CfiDi^e.,  simultaneously  if  in  RPN  mode,  to  access  to  the  PLOT 
SETUP  window. 

•  Change  type  to  Slopefield. 

•  Press        and  type  'X+Y'  Slili. 

•  Make  sure  that  'X'  is  selected  as  the  indep:  and  'Y'  as  the  Depnd: 
variables. 

•  Press  [w^iiiuTjilli  to  return  to  normal  calculator  display. 

•  Press  CfDJ^,  simultaneously  if  in  RPN  mode,  to  access  the  PLOT 
WINDOW  screen. 

•  Change  the  plot  window  ranges  to  read:  X-Left:-5,  X-Right:5,  Y-Near:-5,  Y-Far: 
5 

•  Press  nWS  lilSE]  to  draw  the  slope  field  plot.       Press  ESH  (W] 

to  see  the  plot  unencumbered  by  the  menu  and  with 
identifying  labels. 


■/'/}}} 
/    /    /     1  1 

im 

w  \  \  \ 

^     ^     ^     \  -5.- 

\  — 

•     Press  LA/xrJ[/vxrjElMi  to  leave  the  EDIT  environment. 
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•  Press  l^iiiiMs  to  return  to  the  PLOT  WINDOW  environment.  Then,  press 
L  ON  J  ,  or  (.wxrjiEESi,  to  return  to  normal  calculator  display. 

If  you  could  reproduce  the  slope  field  plot  in  paper,  you  can  trace  by  hand 
lines  that  are  tangent  to  the  line  segments  shown  in  the  plot.  This  lines 
constitute  lines  of  y(x,y)  =  constant,  for  the  solution  of  y'  =  f{x,y).  Thus,  slope 
fields  are  useful  tools  for  visualizing  particularly  difficult  equations  to  solve. 

Try  also  a  slope  field  plot  for  the  function  y'  =  f(x,y)  =  -  (y/x)^,  by  using; 

•  Press  LjnJi'MD  ,  simultaneously  if  in  RPN  mode,  to  access  to  the  PLOT 
SETUP  window. 

•  Change  type  to  Slopefield. 

•  Press  ^  and  type  '-  (Y/X)^ 2' :: :: .:  . 

•  Press  BIlIaIIS  IIMiill!  to  draw  the  slope  field  plot.  Press  IHilElO  [nxtJ 
a=!L'.':':'"j'.'j'"i  to  See  the  plot  unencumbered  by  the  menu  and  with 
identifying  labels. 


—----^^  \  \ 

•  Press  [NXT )lNXT juSai  to  leave  the  EDIT  environment. 

•  Press  iLiEIiMIl  to  return  to  the  PLOT  WINDOW  environment.   Then,  press 
L  ON  J  ,  or  (.wJIBESB,  to  return  to  normal  calculator  display. 

Fast  3D  plots 

Fast  3D  plots  are  used  to  visualize  three-dimensional  surfaces  represented  by 
equations  of  the  form  z  =  f(x,y).  For  example,  if  you  want  to  visualize  z  = 
f(x,y)  =  x^+y^,  we  can  use  the  following: 

•  Press  (JnJiWD  ,  simultaneously  if  in  RPN  mode,  to  access  to  the  PLOT 
SETUP  window. 

•  Change  TYPE  to  Fast3D. 

.     Press  ^  and  type  'X'^2+Y'^2'  lEUlS. 
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Make  sure  that  'X'  is  selected  as  the  Indep:  and  'Y'  as  the  Depnd:  variables. 

Press  [ft/xT-jilBSii  to  return  to  normal  calculator  display. 

Press  l^ML,  simultaneously  if  in  RPN  mode,  to  access  the  PLOT 

WINDOW  screen. 

Keep  the  default  plot  window  ranges  to  read:  X-Left:-1,  X-Right:1,  Y-Near:-1, 
Y-Far:  1,  Z-Low:  -1,  Z-High:  1,  Step  Indep:  10,  Depnd:  8 


Note:  The  Step  Indep:  and  Depnd:  values  represent  the  number  of 
gridlines  to  be  used  in  the  plot.  The  larger  these  number,  the  slower  it 
is  to  produce  the  graph,  although,  the  times  utilized  for  graphic 
generation  are  relatively  fast.  For  the  time  being  we'll  keep  the  default 
values  of  1 0  and  8  for  the  Step  data. 


Press  !]Etj!eI]I  EEEII]  to  draw  the  three-dimensional  surface.  The  result  is  a 
wireframe  picture  of  the  surface  with  the  reference  coordinate  system 
shown  at  the  lower  left  corner  of  the  screen.  By  using  the  arrow  keys 
(CO  CK)  )  you  can  change  the  orientation  of  the  surface.  The 

orientation  of  the  reference  coordinate  system  will  change  accordingly. 
Try  changing  the  surface  orientation  on  your  own.  The  following  figures 
show  a  couple  of  views  of  the  graph: 


When  done,  press 


•  Press  nrnCT  to  return  to  the  PLOT  WINDOW  environment. 

•  Change  the  Step  data  to  read:  step  indep:  20    Depnd:  16 

•  Press  lEilEIPB  iSiiini  to  see  the  surface  plot.  Sample  views: 
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•  when  done,  press  Oillli. 

•  Press  Emm  to  return  to  PLOT  WINDOW. 

•  Press  [oaJ  ,  or  [xxrjEM,  to  return  to  normal  calculator  display. 

Try  also  a  Fast  3D  plot  for  the  surface  z  =  f(x,y)  =  sin  (x^+y^) 

•  Press  C5Di«3o  ,  simultaneously  if  in  RPN  mode,  to  access  the  PLOT  SETUP 
window. 

•  Press  ^  and  type  'SIN(X'^2+Y'^2)'  BI3II. 

•  Press  liEleHliliiil!]  to  draw  the  plot. 

•  When  done,  press  EmS. 

•  Press  "! to  return  to  PLOT  WINDOW. 

•  Press  I  ON  J  ,  or  (.wxT-jiailai,  to  return  to  normal  calculator  display. 


Wireframe  plots 

Wireframe  plots  are  plots  of  three-dimensional  surfaces  described  by  z  =  f(x,y). 
Unlike  Fast  3D  plots,  wireframe  plots  are  static  plots.  The  user  can  choose  the 
viewpoint  for  the  plot,  i.e.,  the  point  from  which  the  surface  is  seen.  For 
example,  to  produce  a  wireframe  plot  for  the  surface  z  =  x  +  2y  -3,  use  the 
following: 

•  Press    [JnJio^o  ,  simultaneously  if  in  RPN  mode,  to  access  to  the  PLOT 
SETUP  window. 

•  Change  TYPE  to  Wireframe. 

•  Press  <::i?  and  type 'X+2*Y-3' lailll. 

•  Make  sure  that  'X'  is  selected  as  the  indep:  and  'Y'  as  the  Depnd: 
variables. 

•  Press  |.A/xrji333B  to  return  to  normal  calculator  display. 

•  Press    [Jnj       ,  simultaneously  if  in  RPN  mode,  to  access  the  PLOT 
WINDOW  screen. 

•  Keep  the  default  plot  window  ranges  to  read:  X-Left:-1,  X-Right:l,  Y-Near:-1, 
Y-Far:  1,  Z-Low:  -1,  Z-High:  1 ,  XE:0,YE:-3,  ZE:0,  Step  Indep:  10  Depnd:  8 
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The  coordinates  XE,  YE,  ZE,  stand  for  "eye  coordinates,"  i.e.,  the  coordinates 
from  which  an  observer  sees  the  plot.  The  values  shown  are  the  default  values. 
The  Step  Indep:  and  Depnd:  values  represent  the  number  of  gridlines  to  be 
used  in  the  plot.  The  larger  these  number,  the  slower  it  is  to  produce  the 
graph.  For  the  time  being  we'll  keep  the  default  values  of  10  and  8  for  the 
Step  data. 

•  Press  Hailli  HEIaIII  to  draw  the  three-dimensional  surface.  The  result  is  a 
wireframe  picture  of  the  surface. 

•  Press  ^MM  [hxt]  yjiiLsiiiLlliiLiiiuE  to  see  the  graph  with  labels  and  ranges.  This 
particular  version  of  the  graph  is  limited  to  the  lower  part  of  the  display. 
We  can  change  the  viewpoint  to  see  a  different  version  of  the  graph. 


.5  V 


•  Press  [^[^yjlHi  SSlEm  to  return  to  the  PLOT  WINDOW  environment. 

•  Change  the  eye  coordinate  data  to  read  :    xe  :  0       ye  :  -3       ze  :  3 

•  Press  iLMiniii  iSiiiS]  to  see  the  surface  plot. 

•  Press  lalHC^T)  HjEti!!  Ellaij]]  to  see  the  graph  with  labels  and  ranges. 


a. 5  V 


This  version  of  the  graph  occupies  more  area  in  the  display  than  the 
previous  one.  We  can  change  the  viewpoint,  once  more,  to  see  another 
version  of  the  graph. 

•  Press  [ NXT J [nxt] mmi  lEiii lilEiijll  to  return  to  the  PLOT  WINDOW  environment. 

•  Change  the  eye  coordinate  data  to  read  :    xe  :  3       ye  :  3       ze  :  3 
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•     Press  '"■"'= to  see  the  surface  plot.  This  time  the  bulk  of  the  plot  is 
located  towards  the  right  -hand  side  of  the  display. 


V 

+  J 

mm 

•  Press  HjEHa  to  return  to  the  PLOT  WINDOW  environment. 

•  Press  I  ON  J  ,  or  [./vxT-jKSaw,  to  return  to  normal  calculator  display. 

Try  also  a  Wireframe  plot  for  the  surface  z  =  f(x,y)  =  x^+y^ 

•  Press  C5Di«3D  ,  simultaneously  if  in  RPN  mode,  to  access  the  PLOT  SETUP 
window. 

•  Press  ^  and  type 'X'^2+Y'^2MyEI]li. 

•  Press         133311  to  draw  the  slope  field  plot.    Press  13333  (W]tBDI]  I533]B 
to  see  the  plot  unencumbered  by  the  menu  and  with  identifying  labels. 


•  Press  [nxt ]Inxt to  leave  the  EDIT  environment. 

•  Press  EEIIHa  to  return  to  the  PLOT  WINDOW  environment.   Then,  press 
L  ON  J  ,  or  lNXT)SS3S,  to  return  to  normal  calculator  display. 

Ps-Contour  plots 

Ps-Confour  plots  are  contour  plots  of  three-dimensional  surfaces  described  by 
z  =  f(x,y).  The  contours  produced  are  projections  of  level  surfaces  z  = 
constant  on  the  x-y  plane.  For  example,  to  produce  a  Ps-Contour  plot  for  the 
surface  z  =  x^+y^,  use  the  following: 
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•  Press  LjnJ  ,  simultaneously  if  in  RPN  mode,  to  access  to  the  PLOT 
SETUP  window. 

•  Change  TYPE  to  Ps-Contour. 

•  Press  ^  and  type 'X'^2+Y'^2' rriTii. 

•  Make  sure  that  'X'  is  selected  as  the  indep:  and  'Y'  as  the  Depnd: 
variables. 

•  Press  [  wxT-  jBEM  to  return  to  normal  calculator  display. 

•  Press  [JjJJM^,  simultaneously  if  in  RPN  mode,  to  access  the  PLOT 
WINDOW  screen. 

•  Keep  the  default  plot  window  ranges  to  read:  X-Left:-2,  X-Rjght:2,  Y-Near:-1 
Y-Far:  1,  Step  Indep:  10,  Depnd:  8 

•  Press  !!T:!T:!'::' ITIT!:  to  draw  the  contour  plot.  This  operation  will  take  some 
time,  so,  be  patient.  The  result  is  a  contour  plot  of  the  surface.  Notice 
that  the  contour  are  not  necessarily  continuous,  however,  they  do  provide 
a  good  picture  of  the  level  surfaces  of  the  function. 

•  Press  BSS^nxt)  ISIillgiS  ilijaH  to  see  the  graph  with  labels  and  ranges. 
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•  Press  (N^DC^SHiii:aMa  to  return  to  the  PLOT  WINDOW  environment. 

•  Press  I  ON  J  ,  or  (wxTiilliiliiii,  to  return  to  normal  calculator  display. 

Try  also  a  Ps-Contour  plot  for  the  surface  z  =  f(x,y)  =  sin  x  cos  y. 

•  Press  CiDi™. ,  simultaneously  if  in  RPN  mode,  to  access  the  PLOT  SETUP 
window. 

.     Press  ^  and  type 'SIN(X)*COS(Y)nilii;Llli. 

•  Press  oililais  ilEIjIu  to  draw  the  slope  field  plot.    Press  ILL v (jwoj  ililaaa  III jIHI 
to  see  the  plot  unencumbered  by  the  menu  and  with  identifying  labels. 


-— —  N  \ 

\m 

-— —  X  / 

/  -1 

\  \  — — - 
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•  Press  [nxt ]Inxt to  leave  the  EDIT  environment. 

•  Press  IH5IiH9  to  return  to  the  PLOT  WINDOW  environment.  Then,  press 
L  ON  J  ,  or  [NXTjSSS,  to  return  to  normal  calculator  display. 

Y-Slice  plots 

Y-Slice  plots  are  animated  plots  of  z-vs.-y  for  different  values  of  x  from  the 
function  z  =  f(x,y).  For  example,  to  produce  a  Y-Slice  plot  for  the  surface  z  = 
x^-xy^,  use  the  follov/ing: 

•  Press  Lfnjj™  ,  simultaneously  if  in  RPN  mode,  to  access  to  the  PLOT 
SETUP  window. 

•  Change  TYPE  to  Y-Slice. 

•  Press  ^  and  type 'X'^3-i-X*Y'^3' ilSIlSS. 

•  Make  sure  that  'X'  is  selected  as  the  Indep:  and  'Y'  as  the  Depnd:  variables. 

•  Press  [wrjiBBSB  to  return  to  normal  calculator  display. 

•  Press  [Jnj  JM_, ,  simultaneously  if  in  RPN  mode,  to  access  the  PLOT 
WINDOW  screen. 

•  Keep  the  default  plot  window  ranges  to  read:  X-Left:-1,  X-Right:l,  Y-Near:-1, 
Y-Far:  1,  Z-Low:-l,  Z-High:1,  Step  Indep:  10  Depnd:  8 

•  Press  "'IT'l-riirr."""  to  draw  the  three-dimensional  surface.  You  will  see  the 
calculator  produce  a  series  of  curves  on  the  screen,  that  will  immediately 
disappear.  When  the  calculator  finishes  producing  all  the  y-slice  curves, 
then  it  will  automatically  go  into  animating  the  different  curves.  One  of 
the  curves  is  shown  below. 


•  Press   L  on  J    to  stop  the  animation.    Press  BxUHi  to  return  to  the  PLOT 
WINDOW  environment. 

•  Press  LiwJ  ,  or  (n><tJ ffllEli,  to  return  to  normal  calculator  display. 
Try  also  a  Ps-Contour  plot  for  the  surface  z  =  f(x,y)  =  (x-l-y)  sin  y. 
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•  Press  [^}m.,  simultaneously  if  in  RPN  mode,  to  access  the  PLOT  SETUP 
window. 

•  Press  ^  and  type  '(X+Y)*SIN(Y)'  mSS. 

•  Press  !.: .: ':. :: ::'  .: .:":.  to  produce  the  Y-Slice  animation. 

•  Press  CowJ  to  stop  the  animation. 

•  Press  luiiiiMI!  to  return  to  the  PLOT  WINDOW  environment.  Then,  press 
L  ON  J  ,  or  [NXT)SS3S,  to  return  to  normal  calculator  display. 

Gridmap  plots 

Gridmap  plots  produce  a  grid  of  orthogonal  curves  describing  a  function  of  a 
complex  variable  of  the  form  w  =f(z)  =  f(x+iy),  where  z  =  x+iy  is  a  complex 
variable.  The  functions  plotted  correspond  to  the  real  and  imaginary  part  of 
w  =  <t(x,y)  +  \W(x,y),  i.e.,  they  represent  curves  <t(x,y)  =constant,  and  ^(x,y) 
=  constant.  For  example,  to  produce  a  Gridmap  plot  for  the  function  w  = 
sin{z),  use  the  following: 

•  Press  UjJ^^  ,  simultaneously  if  in  RPN  mode,  to  access  to  the  PLOT 
SETUP  window. 

•  Change  TYPE  to  Gridmap. 

•  Press  ^  and  type 'SIN(X+i*Y)'ISEIIiS. 

•  Make  sure  that  'X'  is  selected  as  the  Indep:  and  'Y'  as  the  Depnd:  variables. 

•  Press  (jwiJIIIiI!lIEiIi  to  return  to  normal  calculator  display. 

•  Press  [Jnj jw_ ,  simultaneously  if  in  RPN  mode,  to  access  the  PLOT 
WINDOW  screen. 

•  Keep  the  default  plot  window  ranges  to  read:  X-Left:-1,  X-Right:l,  Y-Near:-1 
Y-Far:  1,  XXLefti-l  XXRightil,  YYNear:-! ,  yyFar:  1,  Step  Indep:  10  Depnd:  8 

•  Press  ■LL.L.sL.s.'L.L...  to  draw  the  gridmap  plot.  The  result  is  a  grid  of 
functions  corresponding  to  the  real  and  imaginary  parts  of  the  complex 
function. 

•  Press  isMs  I nxt ) y Ilg j|  IITHlII!  to  see  the  graph  with  labels  and  ranges. 


•     Press  (WKWlyj^Mi  ESMs  to  return  to  the  PLOT  WINDOW  environment. 
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•     Press  I  ON  J  ,  or  (.wxt-jKISB,  to  return  to  normal  calculator  display. 


Other  functions  of  a  complex  variable  worth  trying  for  Gridmap  plots  are: 


(1)SIN((X,Y)) 
(3)  EXP((X,Y)) 
(5)TAN((X,Y)) 
(7)  (X,Y)-3 
(9)V(X,Y) 


i.e.,  F(z; 

i.e.,  F(z; 

i.e.,  F(z; 

i.e.,  F(z; 

i.e.,  F(z; 


=  sin(z) 

=  e' 

=  tan(z) 

=  z3 
=  z^/2 


(2)(X,Y)'^2         i.e.,  F(z)  =  z^ 
(4)  SINH((X,Y))  i.e.,  F(z)  =  sinh(z) 
(6)  ATAN((X,Y))  i.e.,  F(z)  =  tan  ^z) 
(8)1/(X,Y)        i.e.,  F(z)=  1/z 


Pr-Surface  plots 

Pr-Surface  (parametric  surface)  plots  are  used  to  plot  a  three-dimensional 
surface  whose  coordinates  {x,y,z)  are  described  by  x  =  x(X,Y),  y  =  y{X,Y), 
z=z(X,Y),  where  X  and  Y  are  independent  parameters. 


Note:  The  equations  x  =  x(X,Y),  y  =  y(X,Y),  z=z(X,Y)  represent  a  parametric 
description  of  a  surface.  X  and  Y  are  the  independent  parameters.  Most 
textbooks  will  use  (u,v)  as  the  parameters,  rather  than  (X,Y).  Thus,  the 
parametric  description  of  a  surface  is  given  as  x  =  x(u,v),  y  =  y(u,v),  z=z(u,v). 

For  example,  to  produce  a  Pr-Surface  plot  for  the  surface  x  =  x{X,Y)  =  X  sin  Y, 
y  =  y(X,Y)  =  X  cos  Y,  z=z(X,Y)=X,  use  the  following: 


Press   CfDi^;  simultaneously  if  in  RPN  mode,  to  access  to  the  PLOT 
SETUP  window. 
Change  TYPE  to  Pr-Surface. 
Press  ^  and  type  '{X*SIN{Y),  X*COS(Y),  X}'  I 


Make  sure  that  'X'  is  selected  as  the  Indep:  and  'Y'  as  the  Depnd: 
variables. 

Press  lj«iJillEllil  to  return  to  normal  calculator  display. 

Press  LfxJ ,  simultaneously  if  in  RPN  mode,  to  access  the  PLOT 

WINDOW  screen. 

Keep  the  default  plot  window  ranges  to  read:  X-Left:-1,  X-Right:l,  Y-Near:-1, 
Y-Far:  1,  Z-Low:  -1,  Z-High:l,  XE:  0,  YE:-3,  zE:0,  Step  Indep:  10,  Depnd:  8 
Press  [iiiSlaJa luiaiiiJ  to  draw  the  three-dimensional  surface. 


Press  SSiW)  B 


a3  immi  to  see  the  graph  with  labels  and  ranges. 
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•  Press  (wCT](W]|[IHilH11H!|  to  return  to  the  PLOT  WINDOW  environment. 

•  Press  I  ON  J  ,  or  C^LlSftiiiii,  to  return  to  normal  calculator  display. 

The  VPAR  variable 

The  VPAR  (Volume  Parameter)  variable  contains  information  regarding  the 
"volume"  used  to  produce  a  three  dimensional  graph.  Therefore,  you  will  see 
it  produced  whenever  you  create  a  three  dimensional  plot  such  as  FastSD, 
Wireframe,  or  Pr-Surface. 


Interactive  drawing 

Whenever  we  produce  a  two-dimensional  graph,  we  find  in  the  graphics 
screen  a  soft  menu  key  labeled  Pressing  u!Sl3  produces  a  menu  that 

include  the  following  options  (press  [nxt)  to  see  additional  functions): 


-1  1  1  1  ^-_L — 

V 

-6.5 

6.5 

TLinEI  EOK  ICIRCL 

-1  1  1  1  >^_L — 

V 

-6.5 

6.5 

liMHilBMTillil 

DEL  |ERA£E|HEnU 

-1 — 1 — 1 — 1  >^ — 

V 

-6.5 

6.5 

SUE  IREPLIPICTi 

Through  the  examples  above,  you  have  the  opportunity  to  try  out  functions 
LABEL,  MENU,  PICT^,  and  REPL.  Many  of  the  remaining  functions,  such  as 
DOT+,  DOT-,  LINE,  BOX,  CIRCL,  MARK,  DEL,  etc.,  can  be  used  to  draw 
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points,  lines,  circles,  etc.  on  the  graphics  screen,  as  described  below.  To  see 
how  to  use  these  functions  we  will  try  the  following  exercise: 

First,  we  get  the  graphics  screen  corresponding  to  the  following  instructions: 

•  Press  lJjJJ£!S. ,  simultaneously  if  in  RPN  mode,  to  access  to  the  PLOT 
SETUP  window. 

•  Change  type  to  Function,  if  needed 

•  Change  EQ  to  X 

•  Make  sure  that  Indep:  is  set  to  'X'  also 

•  Press  LwjBISBI  to  return  to  normal  calculator  display. 

•  Press  C5JJ^,  simultaneously  if  in  RPN  mode,  to  access  the  PLOT 
window  (in  this  case  it  will  be  called  PLOT  -POLAR  window). 

•  Change  the  H-VIEW  range  to  -10  to  10,  by  using 
CDCoDraiKIHiaDSDBSBSi,  and  the  V-VIEW  range  to  -5  to  5  by 
using  LU CZtD llililLiJ iSililii. 

•  Press  iLilililsljil  IlilliliU  to  plot  the  function. 

•  Press  Ea31j(W)  H3313  to  add  labels  to  the  graph.  Press  lNXT]{N>a]  (or 
[  <-i  jfflfv  )  to  recover  the  original  EDIT  menu. 

Next,  we  illustrate  the  use  of  the  different  drawing  functions  on  the  resulting 
graphics  screen.  They  require  use  of  the  cursor  and  the  arrow  keys 
(C3D  CD  )  to  move  the  cursor  about  the  graphics  screen. 

DOT+  and  DOT- 

When  DOT+  is  selected,  pixels  will  be  activated  wherever  the  cursor  moves 
leaving  behind  a  trace  of  the  cursor  position.  When  DOT-  is  selected,  the 
opposite  effect  occurs,  i.e.,  as  you  move  the  cursor,  pixels  will  be  deleted. 

For  example,  use  the  CT)/aN|  keys  to  move  the  cursor  somewhere  in  the 
middle  of  the  first  quadrant  of  the  x-y  plane,  then  press  iEHlllill.  The  label  will 
be  selected  (!y!yi]II^Hi).  Press  and  hold  the  (X)  key  to  see  a  horizontal  line  being 
traced.  Now,  press  E3S3SI,  to  select  this  option  ( l^uilSlll  ).  Press  and  hold 
the  CT)  key  to  see  the  line  you  just  traced  being  erased.  Press  uSh,  when 
done,  to  deselect  this  option. 
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MARK 

This  command  allows  the  user  to  set  a  mark  point  which  can  be  used  for  a 
number  of  purposes,  such  as: 

•  Start  of  line  with  the  LINE  or  TUNE  command 

•  Corner  for  a  BOX  command 

.     Center  for  a  CIRCLE  command 

Using  the  MARK  command  by  itself  simply  leaves  an  x  in  the  location  of  the 
mark  (Press  |.A/x7-j||Ili|j|i|  to  see  it  in  action). 

LINE 

This  command  is  used  to  draw  a  line  between  two  points  in  the  graph.  To  see 
it  in  action,  position  the  cursor  somewhere  in  the  first  quadrant,  and  press 
[  <-i  ]iwy_fSSS.  A  MARK  is  placed  over  the  cursor  indicating  the  origin  of  the 
line.  Use  the  CB>  key  to  move  the  cursor  to  the  right  of  the  current  position, 
say  about  1  cm  to  the  right,  and  press  «SSS.  A  line  is  draw  between  the  first 
and  the  last  points. 

Notice  that  the  cursor  at  the  end  of  this  line  is  still  active  indicating  that  the 
calculator  is  ready  to  plot  a  line  starting  at  that  point.  Press  ^^3?  to  move  the 
cursor  downwards,  say  about  another  cm,  and  press  IIJIijlil]l  again.  Now  you 
should  have  a  straight  angle  traced  by  a  horizontal  and  a  vertical  segments. 
The  cursor  is  still  active.  To  deactivate  it,  without  moving  it  at  all,  press  113113. 
The  cursor  returns  to  its  normal  shape  (a  cross)  and  the  LINE  function  is  no 
longer  active. 

TUNE 

(Toggle  LINE)  Move  the  cursor  to  the  second  quadrant  to  see  this  function  in 
action.  Press  iiEHIi.  A  MARK  is  placed  at  the  start  of  the  toggle  line.  Move 
the  cursor  with  the  arrow  keys  away  from  this  point,  and  press  llajBl.  A  line 
is  drawn  from  the  current  cursor  position  to  the  reference  point  selected  earlier. 
Pixels  that  are  on  in  the  line  path  will  be  turned  off,  and  vice  versa.  To 
remove  the  most  recent  line  traced,  press  lEfiil:!!  again.  To  deactivate  TLINE, 
move  the  cursor  to  the  original  point  where  TLINE  was  activated,  and  press 

iniiririm 
1X311^  ll^CJllL!!. 
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BOX 

This  command  is  used  to  draw  a  box  in  the  graph.  Move  the  cursor  to  a 
clear  area  of  the  graph,  and  press  EES!.  This  highlights  the  cursor.  Move  the 
cursor  v/ith  the  arrow  keys  to  a  point  away,  and  in  a  diagonal  direction,  from 
the  current  cursor  position.  Press  laSl  again.  A  rectangle  is  drawn  whose 
diagonal  joins  the  initial  and  ending  cursor  positions.  The  initial  position  of 
the  box  is  still  marked  with  and  x.  Moving  the  cursor  to  another  position  and 
pressing  iniGIiill  will  generate  a  new  box  containing  the  initial  point.  To  deselect 
BOX,  move  the  cursor  to  the  original  point  where  BOX  was  activated,  then 
press  imili  IHiiji. 


CIRCL 

This  command  produces  a  circle.  Mark  the  center  of  the  circle  with  a  MARK 
command,  then  move  the  cursor  to  a  point  that  will  be  part  of  the  periphery  of 
the  circle,  and  press  B^EiEEI.   To  deactivate  CIRCL,  return  the  cursor  to  the 
MARK  position  and  press  IHillH. 

Try  this  command  by  moving  the  cursor  to  a  clear  part  of  the  graph,  press 
■HMeI.  Move  the  cursor  to  another  point,  then  press  IIIHeIj!!]!!.  A  circle  centered 
at  the  MARK,  and  passing  through  the  last  point  will  be  drawn. 


LABEL 

Pressing  slLlIal  places  the  labels  in  the  x-  and  y-axes  of  the  current  plot.  This 
feature  has  been  used  extensively  through  this  chapter. 

DEL 

This  command  is  used  to  remove  parts  of  the  graph  between  two  MARK 
positions.  Move  the  cursor  to  a  point  in  the  graph,  and  press  Move 
the  cursor  to  a  different  point,  press  IIII±iiiil  again.  Then,  press  iilSl.  The 
section  of  the  graph  boxed  between  the  two  marks  will  be  deleted. 
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ERASE 

The  function  ERASE  clears  the  entire  graphics  window.  This  command  is 
available  in  the  PLOT  menu,  as  well  as  in  the  plotting  windows  accessible 
through  the  soft  menu  keys. 


MENU 

Pressing  ilijiili  will  remove  the  soft  key  menu  labels  to  show  the  graphic 
unencumbered  by  those  labels.   To  recover  the  labels,  press  Inxt}  . 


SUB 

Use  this  command  to  extract  a  subset  of  a  graphics  object.  The  extracted 
object  is  automatically  placed  in  the  stack.  Select  the  subset  you  want  to 
extract  by  placing  a  MARK  at  a  point  in  the  graph,  moving  the  cursor  to  the 
diagonal  corner  of  the  rectangle  enclosing  the  graphics  subset,  and  press 
ilEillis.   This  feature  can  be  used  to  move  parts  of  a  graphics  object  around  the 
graph. 


REPL 

This  command  places  the  contents  of  a  graphic  object  currently  in  stack  level 
1  at  the  cursor  location  in  the  graphics  window.  The  upper  left  corner  of  the 
graphic  object  being  inserted  in  the  graph  will  be  placed  at  the  cursor 
position.   Thus,  if  you  want  a  graph  from  the  stack  to  completely  fill  the 
graphic  window,  make  sure  that  the  cursor  is  placed  at  the  upper  left  corner 
of  the  display. 


PICT^ 

This  command  places  a  copy  of  the  graph  currently  in  the  graphics  window 
on  to  the  stack  as  a  graphic  object.  The  graphic  object  placed  in  the  stack 
can  be  saved  into  a  variable  name  for  storage  or  other  type  of  manipulation 


This  command  copies  the  coordinates  of  the  current  cursor  position,  in  user 
coordinates,  in  the  stack. 
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Zooming  in  and  out  in  the  graphics  display 

whenever  you  produce  a  two-dimensional  FUNCTION  graphic  interactively, 
the  first  soft-menu  key,  labeled  llsuSiij,  lets  you  access  functions  that  can  be 
used  to  zoom  in  and  out  in  the  current  graphics  display.  The  ZOOM  menu 
includes  the  follov/ing  functions  (press  [nxtJ^o  move  to  the  next  menu): 


We  present  each  of  these  functions  following.  You  just  need  to  produce  a 
graph  as  indicated  in  Chapter  1 2,  or  with  one  of  the  programs  listed  earlier 
in  this  Chapter. 

ZFACT,  ZIN,  ZOUT,  and  ZLAST 

Pressing  : ::.: J.i  produces  an  input  screen  that  allows  you  to  change  the  current 
X-  and  Y-Factors.  The  X-  and  Y-Factors  relate  the  horizontal  and  vertical  user- 
defined  unit  ranges  to  their  corresponding  pixel  ranges.  Change  the  H- 
Factor  to  read  8.,  and  press  ii^lliilil,  then  change  the  V-Factor  to  read  2.,  and 
press  ISulS.  Check  off  the  option  v^Recenter  on  cursor,  and  press  USES. 

Back  in  the  graphics  display,  press  ■!.■..«■  The  graphic  is  re-drawn  with  the 
new  vertical  and  horizontal  scale  factors,  centered  at  the  position  where  the 
cursor  was  located,  while  maintaining  the  original  PICT  size  (i.e.,  the  original 
number  of  pixels  in  both  directions).  Using  the  arrow  keys,  scroll 
horizontally  or  vertically  as  far  as  you  can  of  the  zoomed-in  graph. 

To  zoom  out,  subjected  to  the  H-  and  V-Factors  set  with  ZFACT,  press  I^ECI 
Eiinijl.  The  resulting  graph  will  provide  more  detail  than  the  zoomed-in  graph. 
You  can  always  return  to  the  very  last  zoom  window  by  using  lElliiMy. 
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BOXZ 

Zooming  in  and  out  of  a  given  graph  can  be  performed  by  using  the  soft- 
menu  key  BOXZ.  With  BOXZ  you  select  the  rectangular  sector  (the  "box") 
that  you  want  to  zoom  in  into.  Move  the  cursor  to  one  of  the  corners  of  the 
box  (using  the  arrov/  keys),  and  press "'  Using  the  arrow  keys  once 
more,  move  the  cursor  to  the  opposite  corner  of  the  desired  zoom  box.  The 
cursor  will  trace  the  zoom  box  in  the  screen.  When  desired  zoom  box  is 
selected,  press  islSliU.  The  calculator  will  zoom  in  the  contents  of  the  zoom 
box  that  you  selected  to  fill  the  entire  screen. 

If  you  now  press  B3Ilil,  the  calculator  will  zoom  out  of  the  current  box  using 
the  H-  and  V-Factors,  which  may  not  recover  the  graph  view  from  which  you 
started  the  zoom  box  operation. 


ZDFLT,  ZAUTO 

Pressing  ISHlHi  re-draws  the  current  plot  using  the  default  x-  and  y-ranges,  i.e., 
-6.5  to  6.5  in  x,  and  -3.1  to  3.1  in  y.  The  command  '::"!"!!■:!''!!,  on  the  other 
hand,  creates  a  zoom  window  using  the  current  independent  variable  (x) 
range,  but  adjusting  the  dependent  variable  (y)  range  to  fit  the  curve  (as  when 
you  use  the  function  iiniEi;!  in  the  PLOT  WINDOW  input  form  (OJ*,, 
simultaneously  in  RPN  mode). 

HZIN,  HZOUT,  VZIN  and  VZOUT 

These  functions  zoom  in  and  out  the  graphics  screen  in  the  horizontal  or 
vertical  direction  according  to  the  current  H-  and  V-Factors. 

CNTR 

Zooms  in  with  the  center  of  the  zoom  window  in  the  current  cursor  location. 
The  zooming  factors  used  are  the  current  H-  and  V-Factors. 

ZDECI 

Zooms  the  graph  so  as  to  round  off  the  limits  of  the  x-interval  to  a  decimal 
value. 
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ZINTG 

Zooms  the  graph  so  that  the  pixel  units  become  user-define  units.  For  example, 
the  minimum  PICT  window  has  131  pixels.  When  you  use  ZINTG,  with  the 
cursor  at  the  center  of  the  screen,  the  window  gets  zoomed  so  that  the  x-axis 
extends  from  -64.5  to  65.5. 


ZSQR 

Zooms  the  graph  so  that  the  plotting  scale  is  maintained  at  1:1  by  adjusting 
the  X  scale,  keeping  the  y  scale  fixed,  if  the  window  is  wider  than  taller.  This 
forces  a  proportional  zooming. 

ZTRIG 

Zooms  the  graph  so  that  the  x  scale  incorporates  a  range  from  about  -3n  to 
+371,  the  preferred  range  for  trigonometric  functions. 


Note:  None  of  these  functions  are  programmable.  They  are  only  useful  in 
an  interactive  way.  Do  not  confuse  the  command  ECIIaISIuI  in  the  ZOOM  menu 
with  the  function  ZFACTOR,  which  is  used  for  gas  dynamic  and  chemistry 
applications  (see  Chapter  3). 


The  SYMBOLIC  menu  and  graphs 

The  SYMBOLIC  menu  is  activated  by  pressing  the  [i»«J  key  (fourth  key  from 
the  left  in  fourth  row  from  the  top  of  the  keyboard).  This  menu  provides  a  list 
of  menus  related  to  the  Computer  Algebraic  System  or  CAS,  these  are: 


^YHEOLIC  HEnU 

l.ALGEERA..  II 

2.HRITHHETIC..  1 

CALCULUS..  1 

H. GRAPH..  1 

5.  SOLVER..  1 

«.TRI«iOnOHETRIC..  Q 

1         1         1  ICHnCLl 

OK 

^YHEOLIC  HEAU 


ARITHHETIC. 
CALCULUS.. 
GRAPH.. 
SOLVER.. 

TRIGOnOHETRIC. 


CAACL  OH 


All  but  one  of  these  menus  are  available  directly  in  the  keyboard  by  pressing 
the  appropriate  keystroke  combination  as  follows.  The  Chapter  of  the  user 
manual  where  the  menus  are  described  is  also  listed: 
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ALGEBRA.. 

ARITHMETIC. 

CALCULUS.. 

SOLVER.. 

TRIGONOMETRIC. 
EXP&LN.. 


CZD^  (theQD  key)  Ch.  5 

(^mm  (theCTD  key)  Ch.  5 

(^cMc_  (theCTD  key)  Ch.  13 

[Jnjssy_  (theCZD  key)  Ch.  6 

[J^_B!c  (theCB  key)  Ch.  5 

(3r]£xmA/  (theCU  key)  Ch.  5 


The  SYMB/GRAPH  menu 

The  GRAPH  sub-menu  within  the  SYMB  menu  includes  the  following  functions: 


^YHEOLIC  GRAPH  HEHU 

l.DEFinE  II 

a.GROeADD  1 

3. PLOT  1 

H.PLOTADD  1 

5. put  ist<l{r.. 

e.flGnTAE  11 

1         1         1  ICHTKiT 

OK 

^YHPOLIC  GRAPH  HEnU 

H.PLOTADD  n 

5. put  istuf.. 

G.^ianTAP  1 

7.TAPVAL  1 

S.TAPVAR  1 

S.SVHEOLIC.  II 

1    1    1  mm 

OH 

DEFINE:  same  as  the  keystroke  sequence  [  <n  J pg    (the  (.  2  J  key) 
GROBADD:  pastes  two  GROBs  first  over  the  second  (See  Chapter  22) 
PLOT(f unction):  plots  a  function,  similar  to  UnJio^o 

PLOTADD(function):  adds  this  function  to  the  list  of  functions  to  plot,  similar  to 
Plot  setup..:  same  as  C5Di^ 

SIGNTAB(function):  sign  table  of  given  function  showing  intervals  of  positive 
and  negative  variation,  zero  points  and  infinite  asymptotes 
TABVAL:  table  of  values  for  a  function 
TABVAR:  variation  table  of  a  function 

Examples  of  some  of  these  functions  are  provided  next. 

PLOT(X^2-l )  is  similar  to  CSDioso  with  EQ:  X'^2  -1 .  Using  ISSSSil  EEEH 
produces  the  plot: 


PLOT  SETUP 


In<l«p:K  _JiHUlt 
H-TicR:lD.  V-TicR:lD. 
Chmi  tapi  Of  put 


iConnsct 


AHES>  ERASE  DRAH 
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PLOTADD{X''2-X)  is  similar  to  (2D but  adding  this  function  to  EQ:X''2-1. 


H-Tich:lD.  V-Tich:lD. 

ch**f<  ■tap<  *f  put 

TABVAL(X'^2-1  ,{1 ,  3})  produces  a  list  of  {min  max}  values  of  the  function  in  the 

interval  {1,3},  while  SIGNTAB(X''2-1 )  shows  the  sign  of  the  function  in  the 


interval  (-oo,+),  with  f{x)  >  0  in  (-oo,-1),  f(x)  <0,  in  (-1,1 


:  TREVRl(x^- 

1/1  3>) 

1  {{1  3}  {0  S}}} 

:SIGHTRb[x^ 

-l) 



+  -1  -  1  +  +«■} 

CHICHI  HELP  1         1         1  1 

,  and  f{x)  >  0  in  (1,+  oo). 


TABVAR(LN(X)/X)  produces  the  following  table  of  variation: 

I  LML^J  I 


TflBVRR 


X 


C    'LHtXVX'   t  t 

f?'    '0+0'  +  'EXP<1>'  - 

'+»'  'T"     'T"     '«.'  t 

'  i^EXPa  V     +:  0  J  J 

Graphiic  113  x  131  J 


t^KIP  SKIP-H  H)EL   DEL-f  DEL  L  inS  i 


A  detailed  interpretation  of  the  table  of  variation  is  easier  to  follow  in  RPN 
mode: 


^-  X 

x4-LHCX) 
^     ■  SQCX) 

_      -f'l  klf'V'^-i  1 

ZOOM  |(K,V) 

TRACE 

"Cn  |EDIT|CAnCL 

- '  = 

->: 


X.^-LHCX) 

■  SQCX!) 
-(LHCX)-l) 


ZOOH  KK.Y)  TRACE   FCA    EDIT  CAACL 


Variation  table: 


-«  ?  0+0  +  -  +«  X 
??   «■  t-y-;-+:0F 


ZOOM  |(X^Y)|TRACE|  FCn  |  EDIT  ICAACL 
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The  output  is  in  a  graphical  format,  showing  the  original  function,  F(X),  the 
derivative  F'(X)  right  after  derivation  and  after  simplification,  and  finally  a 
table  of  variation.  The  table  consists  of  tv/o  rov/s,  labeled  in  the  right-hand 
side.  Thus,  the  top  row  represents  values  of  X  and  the  second  row  represents 
values  of  F.  The  question  marks  indicates  uncertainty  or  non-definition.  For 
example,  for  X<0,  LN(X)  is  not  defined,  thus  the  X  lines  shows  a  question  mark 
in  that  interval.  Right  at  zero  (0+0)  F  is  infinite,  for  X  =  e,  F  =  1/e.  F 
increases  before  reaching  this  value,  as  indicated  by  the  upward  arrow,  and 
decreases  after  this  value  (X=e)  becoming  slightly  larger  than  zero  (+:0)  as  X 
goes  to  infinity.  A  plot  of  the  graph  is  shown  below  to  illustrate  these 
observations: 


-K- 


Function  DRAW3DMATRIX 

This  function  takes  as  argument  a  nxm  matrix,  Z,  =  [  Z|j],  and  minimum  and 
maximum  values  for  the  plot.  You  want  to  select  the  values  of  w^^^  and  v^^^  so 
that  they  contain  the  values  listed  in  Z.  The  general  call  to  the  function  is, 
therefore,  DRAW3DMATRIX(Z,v^i„v™J.  To  illustrate  the  use  of  this  function 
we  first  generate  a  6x5  matrix  using  RANM({6,5}),  and  then  call  function 
DRAWS DMATRIX,  as  shown  below: 


-e  -s  -e  -e  s  ■ 

7-5003 
5  -e  -H  -3  -s 
-3  H    ?    g  S 
5  -1  H  -H  1 

.7  -H  -5  7  -7. 

EDITIVIEHI  RCL  |  £T0^  IPURGEICLEHR 

X 

-U  3 

7-5  0    0  3 

5  -e  -H  -3  -S 

-3  H    ?    g  S 

5  -1  H  -H  1 

.7  -H  -5  7  -7. 

:DRAH3DHHTRIX(Hn£(l).-10.10) 

HOVRL 

EDITIVIEHI  RCL  |  £T0^  IRURGEICLEAR 

The  plot  is  in  the  style  of  a  FAST3DPLOT.  Different  views  of  the  plot  are  shown 
below: 

I, 


Page  1 2-54 


Chapter  13 
Calculus  Applications 

In  this  Chapter  we  discuss  applications  of  the  calculator's  functions  to 
operations  related  to  Calculus,  e.g.,  limits,  derivatives,  integrals,  power  series, 
etc. 

The  CALC  (Calculus)  menu 

Many  of  the  functions  presented  in  this  Chapter  are  contained  in  the 
calculator's  CALC  menu,  available  through  the  keystroke  sequence  [  <n  )cak: 
(associated  with  the  I  4  J  key).  The  CALC  menu  shows  the  following  entries: 


CHLC  HEnU 

l.DERIV.  &  inTEfl...  1 

2. LIMITS  &  £ERIE£.. 

^.DIFFEREnriHL  E6\\i.. 

H.GRHPH.. 

5.DERVX 

fi.inrvK 

1         1         1  ICHnCLl 

OK 

The  first  four  options  in  this  menu  are  actually  sub-menus  that  apply  to  (1) 
derivatives  and  integrals,  (2)  limits  and  power  series,  (3)  differential 
equations,  and  (4)  graphics.  The  functions  in  entries  (1)  and  (2)  will  be 
presented  in  this  Chapter.  Differential  equations,  the  subject  of  item  (3),  are 
presented  in  Chapter  16.  Graphic  functions,  the  subject  of  item  (4),  were 
presented  at  the  end  of  Chapter  12.  Finally,  entries  5.  DERVX  and  6.INTVX 
are  the  functions  to  obtain  a  derivative  and  a  indefinite  integral  for  a  function 
of  the  default  CAS  variable  (typically,  'X').  Functions  DERVX  and  INTVX  are 
discussed  in  detail  later. 

Limits  and  derivatives 

Differential  calculus  deals  with  derivatives,  or  rates  of  change,  of  functions 
and  their  applications  in  mathematical  analysis.  The  derivative  of  a  function 
is  defined  as  a  limit  of  the  difference  of  a  function  as  the  increment  in  the 
independent  variable  tends  to  zero.  Limits  are  used  also  to  check  the 
continuity  of  functions. 


Page  1 3-1 


Function  lim 

The  calculator  provides  function  lim  to  calculate  limits  of  functions.  Tfiis 
function  uses  as  input  an  expression  representing  a  function  and  the  value 
where  the  limit  is  to  be  calculated.  Function  lim  is  available  through  the 
command  catalog  (Lr?J_ar  [alphaOjjJCB  )  or  through  option  2.  LIMITS  & 
SERIES...  of  the  CALC  menu  (see  above). 


Note:  The  functions  available  in  the  LIMITS  &  SERIES  menu  are  shov/n  next: 


LIMITS      SERIES  HEHU 

l.DIVPC  1 

2.  LiH 

H.TflVLORD 

S.TflVLR 

CALCULUS.. 

HELPi       1       1  IcflncUr 

OK 

Function  DIVPC  is  used  to  divide  two  polynomials  producing  a  series 
expansion.  Functions  DIVPC,  SERIES,  TAYLORO,  and  TAYLOR  are  used  in 
series  expansions  of  functions  and  discussed  in  more  detail  in  this  Chapter. 


Function  lim  is  entered  in  ALG  mode  as  1  imtf  ;i  x==a^  to  calculate  the 
limit  lim  f{x)  .  In  RPN  mode,  enter  the  function  first,  then  the  expression 

'x=a',  and  finally  function  lim.  Examples  in  ALG  mode  are  shown  next, 
including  some  limits  to  infinity.  The  keystrokes  for  the  first  example  are  as 
follows  (using  Algebraic  mode,  and  system  flag  1 1 7  set  to  CHOOSE  boxes): 


:  lim(X+l) 

2 

:  liJx^-s) 
X+1 

-1 

1 

CHICHI  HELPI         1         1  1 

CHICHI  HELPI         1         1  1 

0 


+^KIP|SKIP^  H)EL  I  DEL-f|DEL  L|  inS  ■ 


The  infinity  symbol  is  associated  with  the  I  0  J  key,  i.e..,  I  *i  Jpo  . 
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Derivatives 

The  derivative  of  a  function  f(x)  at  x  =  a  is  defined  as  thie  limit 

dx  >'->o  h 

Some  examples  of  derivatives  using  thiis  limit  are  shov/n  in  the  following 
screen  shots: 


x+hi  X 

e  -e 

i      hi  J 

hi-*0 

X 

e 

Functions  DERIV  and  DERVX 

The  function  DERIV  is  used  to  take  derivatives  in  terms  of  any  independent 
variable,  while  the  function  DERVX  takes  derivatives  with  respect  to  the  CAS 
default  variable  VX  (typically  'X').  While  function  DERVX  is  available  directly 
in  the  CALC  menu,  both  functions  are  available  in  the  DERIV.&INTEG  sub- 
menu within  the  CALCL  menu  ( I  <n  Jgjtc. ). 

Function  DERIV  requires  a  function,  say  f(t),  and  an  independent  variable,  say, 
t,  while  function  DERVX  requires  only  a  function  of  VX.  Examples  are  shown 
next  in  ALG  mode.  Recall  that  in  RPN  mode  the  arguments  must  be  entered 
before  the  function  is  applied. 


:DERIv(t.e^,t) 

:DERIV(SIH(s),s) 

costs) 

DERVX(JX-X) 


-[[-l+2-Jx)-Jx) 


The  DERIV&INTEG  menu 

The  functions  available  in  this  sub-menu  are  listed  below: 
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DERIV.  a  inTEfl.  HEnu 


2.DERIV 

?.DERVX 

H.DIV 

5. FOURIER 


10.  FREVAL 

11.  RI^CH 
la.^IGHA 


IH.CALCULU;.. 


DERIV.  a  inTEfl.  HEnu 


3.LARL 

10.  FREVAL 

11.  RI^CH 

12.  £IGHA 


DERIV.  &  IRTEG.  HERU 


Out  of  these  functions  DERIV  and  DERVX  are  used  for  derivatives.  Tfie  otfier 
functions  include  functions  related  to  anti-derivatives  and  integrals  (IBP,  INTVX, 
PREVAL,  RISCH,  SIGMA,  and  SIGMAVX),  to  Fourier  series  (FOURIER),and  to 
vector  analysis  (CURL,  DIV,  HESS,  LAPL).  Next  we  discuss  functions  DERIV 
and  DERVX,  tfie  remaining  functions  are  presented  eitfier  later  in  tfiis  Cfiapter 
or  in  subsequent  Cfiapters. 

Calculating  derivatives  with  d 

Tfie  symbol  is  available  as  I  r»  J  ^  (the  jcos  j  key).  This  symbol  can  be  used 

to  enter  a  derivative  in  the  stack  or  in  the  Equation  Writer  (see  Chapter  2).  If 
you  use  the  symbol  to  v/rite  a  derivative  into  the  stack,  follov/  it  immediately 
with  the  independent  variable,  then  by  a  pair  of  parentheses  enclosing  the 
function  to  be  differentiated.  Thus,  to  calculate  the  derivative  d(sin(r),r),  use, 
in  ALG  mode:  CZD  ^^!^C5J(SC5J'J.  C»D(d™)C5D(51(^ 


In  RPN  mode,  this  expression  must  be  enclosed  in  quotes  before  entering  it 
into  the  stack.  The  result  in  ALG  mode  is: 


:^(SIH(r)) 

COS(r) 

In  the  Equation  Writer,  when  you  press  isL)  ^  ,  the  calculator  provides  the 

following  expression: 


Page  1 3-4 


EDIT  I  CUR£  I  EIG  *\  EVHL  |FHCTO|  £IHP 


The  insert  cursor  (^)  will  be  located  right  at  the  denominator  awaiting  for  the 

user  to  enter  an  independent  variable,  say,  s:  (d™]UnJ(|] .  Then,  press  the 
right-arrow  key  (CD)  to  move  to  the  placeholder  between  parentheses: 


EDIT  I  CUR£  I  EIG  ■!  EVHL  |FHCTO|  £IHP 


Next,  enter  the  function  to  be  differentiated,  say,  s*ln{s): 


EDIT  I  CUR£  I  EIG  ■!  EVHL  |FHCTD|  £IHP 


To  evaluate  the  derivative  in  the  Equation  Writer,  press  the  up-arrow  key 
four  times,  to  select  the  entire  expression,  then,  press  laSila.  The  derivative  will 
be  evaluated  in  the  Equation  Writer  as: 


EDIT  I  CUR£  I  EIG  ■!  EVHL  |FHCTD|  £IHP 


Note:  The  symbol  d  is  used  formally  in  mathematics  to  indicate  a  partial 
derivative,  i.e.,  the  derivative  of  a  function  with  more  than  one  variable. 
However,  the  calculator  does  not  distinguish  between  ordinary  and  partial 
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derivatives,  utilizing  the  same  symbol  for  both.  The  user  must  keep  this 
distinction  in  mind  v^hen  translating  results  from  the  calculator  to  paper. 


The  chain  rule 

The  chain  rule  for  derivatives  applies  to  derivatives  of  composite  functions.  A 
general  expression  for  the  chain-rule  is  d{f[g(x)]}/dx  =  (df/dg)-  (dg/dx). 
Using  the  calculator,  this  formula  results  in: 


EDIT  1  CURS  1  EIG     EVflL  |FflCTO|  SIMP 

EDI^UR^lS^VflnFfiaoniMr 

The  terms  d1  in  front  of  g(x)  and  f(g(x))  in  the  expression  above  are 
abbreviations  the  calculator  uses  to  indicate  a  first  derivative  v^hen  the 
independent  variable,  in  this  case  x,  is  clearly  defined.  Thus,  the  latter  result  is 
interpreted  as  in  the  formula  for  the  chain  rule  shown  above.  Here  is  another 
example  of  a  chain  rule  application: 


EDIT  1  CURS  1  EIG  -\  EVflL  |FflCTD|  SIMP 

EDIT  1  CURS  1  RIG  -\  EVflL  |FflCTD|  SIMP 

Derivatives  of  equations 

You  can  use  the  calculator  to  calculate  derivatives  of  equations,  i.e., 
expressions  in  v/hich  derivatives  v/ill  exist  in  both  sides  of  the  equal  sign. 
Some  examples  are  shown  below: 


cdlx(t)=2 

-(siH(e(t)>cdie(t)) 

x^-3.x) 

cdly(x)=2.x-3 

DERIv(hi(t)=LH(t^-lU] 
2-t 


cdlhi(t)= 
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:  DERVX(Y(X)=TRH(X)) 

dlY(X)-(TRH(X)^+l. 
:  DERVX(G(X)=X.LH(X)) 
^^^^^^^^^^^^ 

Notice  that  in  the  expressions  where  the  derivative  sign  (9)  or  function  DERIV 
was  used,  the  equal  sign  is  preserved  in  the  equation,  but  not  in  the  cases 
where  function  DERVX  was  used.  In  these  cases,  the  equation  was  re-written 
with  all  its  terms  moved  to  the  left-hand  side  of  the  equal  sign.  Also,  the  equal 
sign  was  removed,  but  it  is  understood  that  the  resulting  expression  is  equal  to 
zero. 

Implicit  derivatives 

Implicit  derivatives  are  possible  in  expressions  such  as: 


^[xct)^=Ci-Hxct:)f) 

EDIT  1  CURS  1  EIG  -\  EVflL  |FflCTO|  SIMP 

EDIT  1  CURS  1  RIG  |  EVflL  |FflCTD| SIMP 

Application  of  derivatives 

Derivatives  can  be  used  for  analyzing  the  graphs  of  functions  and  for 
optimizing  functions  of  one  variable  (i.e.,  finding  maxima  and  minima). 
Some  applications  of  derivatives  are  shown  next. 

Analyzing  graphics  of  functions 

In  Chapter  1  1  we  presented  some  functions  that  are  available  in  the  graphics 
screen  for  analyzing  graphics  of  functions  of  the  form  y  =  f(x).  These 
functions  include  (X,Y)  and  TRACE  for  determining  points  on  the  graph,  as 
well  as  functions  in  the  ZOOM  and  FCN  menu.  The  functions  in  the  ZOOM 
menu  allow  the  user  to  zoom  in  into  a  graph  to  analyze  it  in  more  detail. 
These  functions  are  described  in  detail  in  Chapter  1  2.  Within  the  functions  of 
the  FCN  menu,  we  can  use  the  functions  SLOPE,  EXTR,  F',  and  TANL  to 
determine  the  slope  of  a  tangent  to  the  graph,  the  extreme  (minima  and 
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maxima)  of  the  function,  to  plot  the  derivative,  and  to  find  the  equation  of  the 
tangent  line. 


Try  the  following  example  for  the  function  y  =  tan(x). 

•  Press  (jjJ^SHH,  simultaneously  in  RPN  mode,  to  access  to  the  PLOT 
SETUP  v^indov/. 

•  Change  TYPE  to  FUNCTION,  if  needed,  by  using  [Sfllia3a]. 

•  Press        and  type  in  the  equation  'TAN(X)'. 

•  Make  sure  the  independent  variable  is  set  to  'X'. 

•  Press  [nxt]  ii!iii.£iia||i  to  return  to  normal  calculator  display. 

•  Press  LJxJ  J!^ ,  simultaneously,  to  access  the  PLOT  v/indov/ 

•  Change  H-VIEW  range  to  -2  to  2,  and  V-VIEW  range  to  -5  to  5. 

•  Press  eEEeHI  SjliSIl]  to  plot  the  function  in  polar  coordinates. 
The  resulting  plot  looks  as  follows: 


/ 

Fa 

•  Notice  that  there  are  vertical  lines  that  represent  asymptotes.  These 
are  not  part  of  the  graph,  but  shov/  points  v/here  TAN(X)  goes  to  ±  oo 
at  certain  values  of  X. 

•  Press  Saaaa^  I(3!H)I,  and  move  the  cursor  to  the  point  X:  1 .08E0,  Y: 
1.86E0.  Next,  press  (W]SS51  EilEEEs.  The  result  is  Slope: 
4.45010547846. 

•  Press  [nxt]Inxt)uSiSs.  This  operation  produces  the  equation  of  the 
tangent  line,  and  plots  its  graph  in  the  same  figure.  The  result  is 
shown  in  the  figure  below: 


/ 

Lirn:  V=H.H5Dj 

.D5H?gHSKK-a.! 

/ 
3HS 
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Press  [nxt]  IsiSi  SiiiiMI!  LonJ  to  return  to  normal  calculator  display. 
Notice  that  the  slope  and  tangent  line  that  you  requested  are  listed  in 
the  stack. 


Function  DOMAIN 

Function  DOMAIN,  available  through  the  command  catalog  ([    J  cat_  ), 

provides  the  domain  of  definition  of  a  function  as  a  list  of  numbers  and 
specifications.  For  example. 


DOMRIHtLHtX)) 


{-»  ?  0  +  +»} 


CH^CH  HELP 


indicates  that  betv/een  -oo  and  0,  the  function  LN(X)  is  not  defined  (?),  while 
from  0  to  +00,  the  function  is  defined  {+).  On  the  other  hand. 


domrih[Ji-x^) 

{-«.  ?  -1  +  1  ?  +«.} 


CH^CH  HELP 


indicates  that  the  function  is  not  defined  betv/een  ^  and  -1,  nor  betv/een  1 
and  +00.  The  domain  of  this  function  is,  therefore,  -1  <X<1 . 


Function  TABVAL 

This  function  is  accessed  through  the  command  catalog  or  through  the  GRAPH 
sub-menu  in  the  CALC  menu.  Function  TABVAL  takes  as  arguments  a  function 
of  the  CAS  variable,  f(X),  and  a  list  of  two  numbers  representing  a  domain  of 
interest  for  the  function  f(X).  Function  TABVAL  returns  the  input  values  plus  the 
range  of  the  function  corresponding  to  the  domain  used  as  input.  For 
example. 


CflSCH  HELP 
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This  result  indicates  that  the  range  of  the  function  J  {X)  = 


4x^\ 

,     ,  fV2  V26l 

corresponding  to  the  domain  D  =  { -1 ,5  }  is  R  =  i  ,  >  . 

I  2     26  I 

Function  SIGNTAB 

Function  SIGNTAB,  available  through  the  command  catalog  ((j^l  ca^ 
provides  information  on  the  sign  of  a  function  through  its  domain.  For 
example,  for  the  TAN(X)  function, 


SIGHTRECTRH(X)3 

|-»  ?  -|  -  0  +  ^  ?  +«■} 


CH^CH  HELP 


SIGNTAB  indicates  that  TAN(X)  is  negative  between  -n/2  and  0,  and  positive 
betv/een  0  and  n  /I.  For  this  case,  SIGNTAB  does  not  provide  information 
(?)  in  the  intervals  between  -<a  and  -tt  /2,  nor  between  +7t  /2  and  oo.  Thus, 
SIGNTAB,  for  this  case,  provides  information  only  on  the  main  domain  of 
TAN(X),  namely  -7t  /2  <  X  <  +71  /2. 


A  second  example  of  function  SIGNTAB  is  shown  below: 


SIGHTRB 


CflSCM  HELP 


X+IJ 

i-f>  1  +  +»} 


For  this  case,  the  function  is  negative  for  X<-1  and  positive  for  X>  -1 . 
Function  TABVAR 

This  function  is  accessed  through  the  command  catalog  or  through  the  GRAPH 
sub-menu  in  the  CALC  menu.  It  uses  as  input  the  function  f(VX),  where  VX  is 
the  default  CAS  variable.  The  function  returns  the  following,  in  RPN  mode: 


•     Level  3:  the  function  f(VX) 
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•  Two  lists,  the  first  one  indicates  the  variation  of  the  function  (i.e., 
where  it  Increases  or  decreases)  in  terms  of  the  independent  variable 
VX,  the  second  one  indicates  the  variation  of  the  function  in  terms  of 
the  dependent  variable. 

•  A  graphic  object  showing  how  the  variation  table  was  computed. 

Example:  Analyze  the  function  Y  =  X'^-4X^-1  lX+30,  using  the  function 
TABVAR.  Use  the  following  keystrokes,  in  RPN  mode: 

'X---3-4*X--^£:-ll*H+:38'  (^CS_«7;  (^(3  (select  TABVAR)  ffiaS 

This  is  what  the  calculator  shows  in  stack  level  1 : 
i:  Graphic  113  x  95 


Graphic 


-+X^-ll.X+30) 

F'=:(3.X^-+2.X-ll] 
->:CC3.X-11XX+1)) 

tJ-.L-n   -.4-    n  .-.r-.  4-   


This  is  a  graphic  object.  To  be  able  to  the  result  in  its  entirety,  press  . 
The  variation  table  of  the  function  is  shown  as  follows: 


r-T  ■  ■  i  i  /  XI  ■  ■  J./^  

Variation  table: 
-»  +  -l-  ++«X 

-«■  t  36  t  +«■  F 


ZOOM  |(K,V)|TRflCE|  FCn  |  EDIT  |CflnCL 


Press  (.  ON  J  to  recover  normal  calculator  display.  Press  (.  J  to  drop  this  last 
result  from  the  stack. 

Two  lists,  corresponding  to  the  top  and  bottom  rows  of  the  graphics  matrix 
shown  earlier,  now  occupy  level  1 .  These  lists  may  be  useful  for 
programming  purposes.    Press  I    J  to  drop  this  last  result  from  the  stack. 
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The  interpretation  of  the  variation  table  shown  above  is  as  follows:  the 
function  F(X)  increases  for  X  in  the  interval  (-00,  -1),  reaching  a  maximum  equal 
to  36  at  X  =  -1 .  Then,  F(X)  decreases  until  X  =  1 1  /3,  reaching  a  minimum  of 
-400/27.  After  that  F(X)  increases  until  reaching  +00.  Also,  at  X  =  ±00,  F(X)= 
±00. 


Using  derivatives  to  calculate  extreme  points 

"Extreme  points,"  or  extrema,  is  the  general  designation  for  maximum  and 
minimum  values  of  a  function  in  a  given  interval.  Since  the  derivative  of  a 
function  at  a  given  point  represents  the  slope  of  a  line  tangent  to  the  curve  at 
that  point,  then  values  of  x  for  which  f'(x)  =0  represent  points  where  the  graph 
of  the  function  reaches  a  maximum  or  minimum.  Furthermore,  the  value  of 
the  second  derivative  of  the  function,  f"(x),  at  those  points  determines  whether 
the  point  is  a  relative  or  local  maximum  [f"(x)<0]  or  minimum  [f"(x)>0].  These 
ideas  are  illustrated  in  the  figure  below. 


In  this  figure  we  limit  ourselves  to  determining  extreme  points  of  the  function  y 
=  f(x)  in  the  x-interval  [a,b].  Within  this  interval  we  find  two  points,  x  =  x^ 
and  X  =  x^^,  where  f'(x)=0.  The  point  x  =  x^,  where  f"(x)>0,  represents  a  local 
minimum,  while  the  point  x  =  x^,  where  f"(x)<0,  represents  a  local  maximum. 
From  the  graph  of  y  =  f(x)  it  follows  that  the  absolute  maximum  in  the  interval 
[a,b]  occurs  at  x  =  a,  while  the  absolute  minimum  occurs  at  x  =  b. 
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For  example,  to  determine  where  the  critical  points  of  function  'X'^3-4*X'^2- 


-ii'X+se 

-4.X^- 

-ll.X+30 

:  DERVX(F) 

[3'X- 

llMX+11 

X  -4.x  - 1 1  ■X+30^ 

DERVX(F) 

O^X-llMX+m 
SOLVEVXtflHSd)) 


We  find  two  critical  points,  one  at  x  =  11/3  and  one  at  x  =  -1 .  To  evaluate 
the  second  derivative  at  each  point  use: 


:  utKVWihJ 

O'X-llMX+U 
SOLVEVXtflHSd)] 


DERVX(DERVX(F)5frFPP 

(3.X-4>a 


suest[fpp,x=-^] 


■^HUMtflHStD) 


14. 


The  last  screen  shows  that  f"(ll/3)  =  14,  thus,  x  =  11/3  is  a  relative 
minimum.  For  x  =  -1 ,  we  have  the  following: 


-  3  " 

:-*HUM(flHS(l)) 

14. 

:SUEST(FPP,X=-1) 

6-1-8 

:-*HUM(flHS(l)) 

-14. 

This  result  indicates  that  f"(-l)  =  -14,  thus,  x  =  -1  is  a  relative  maximum. 
Evaluate  the  function  at  those  points  to  verify  that  indeed  f(-l)  >  f(l  1/3). 


■*hum[subst[f,x=-^]] 

-14.S14S14S151 
■*HUM(SUBST(F,X=-1)) 

36 


Higher  order  derivatives 

Higher  order  derivatives  can  be  calculated  by  applying  a  derivative  function 
several  times,  e.g., 
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COS(X)+CO|(X)+X-S  I  H(X) 
2-3 


+^KIP|SKIP^  H)EL  I  DEL-f|DEL  L|  inS  ■ 


Anti-derivatives  and  integrals 

An  anti-derivative  of  a  function  f(x)  is  a  function  F(x)  such  that  f(x)  =  dF/dx. 
For  example,  since  d(x'^)  /dx  =  3x^,  an  anti-derivative  of  f(x)  =  3x^  is  F(x)  = 
+  C,  v/here  C  is  a  constant.  One  way  to  represent  an  anti-derivative  is  as  a 

indefinite  integral,  i.e.,  ^f{x)dx  =  F{x)  +  C ,  if  and  only  if,  f(x)  =  dF/dx, 
and  C  =  constant. 

Functions  INT,  INTVX,  RISCH,  SIGMA  and  SIGMAVX 

The  calculator  provides  functions  INT,  INTVX,  RISCH,  SIGMA  and  SIGMAVX 
to  calculate  anti-derivatives  of  functions.  Functions  INT,  RISCH,  and  SIGMA 
work  with  functions  of  any  variable,  while  functions  INTVX,  and  SIGMAVX 
utilize  functions  of  the  CAS  variable  VX  (typically,  'x').    Functions  INT  and 
RISCH  require,  therefore,  not  only  the  expression  for  the  function  being 
integrated,  but  also  the  independent  variable  name.  Function  INT,  requires 
also  a  value  of  x  where  the  anti-derivative  will  be  evaluated.  Functions  INTVX 
and  SIGMAVX  require  only  the  expression  of  the  function  to  integrate  in  terms 
of  VX.  Some  examples  are  shown  next  in  ALG  mode: 


IHTVX 


(X.e^) 


(X-l>e 

IHTVX(RSIH(X» 

■Jl-SQ(X)-HXflSIH(X) 


lEP  linrVKI  LflPL  |PREVfl|RISCH|SIGMfl 


SIGMRVXt(X-3)!) 


SIGMR 


X! 
X-0 


X-1 


X-2 


.X 


RISCH(j^-fjf) 


3  a 


IRP  linTVKI  LflPL  |PREVfl|RISCH|SIGMfl 


IRP   inrVX  LHRL  RREVH  RI^CH^IGHH 
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Please  notice  that  functions  SIGMAVX  and  SIGMA  are  designed  for 
integrands  that  involve  some  sort  of  integer  function  like  the  factorial  (!) 
function  shown  above.  Their  result  is  the  so-called  discrete  derivative,  i.e., 
one  defined  for  integer  numbers  only. 

Definite  integrals 

In  a  definite  integral  of  a  function,  the  resulting  anti-derivative  is  evaluated  at 
the  upper  and  lower  limit  of  an  interval  (a,b)  and  the  evaluated  values 

subtracted.  Symbolically,     f(x)dx  =  F{b)  —  F{a),  where  f(x)  =  dF/dx. 


The  PREVAL(f(x),a,b)  function  of  the  CAS  can  simplify  such  calculation  by 
returning  f(b)-f(a)  with  x  being  the  CAS  variable  VX. 


PREVRl13.X'^-X,0,5J 
PREVRL(X.LH(X)4.5) 


70 


To  calculate  definite  integrals  the  calculator  also  provides  the  integral  symbol 

as  the  keystroke  combination  L    J  [  (associated  with  the  I  tan  j  key).  The 

simplest  way  to  build  an  integral  is  by  using  the  Equation  Writer  (see  Chapter 

2  for  an  example).  Within  the  Equation  Writer,  the  symbol  LrlJ  I 

produces  the  integral  sign  and  provides  placeholders  for  the  integration  limits 
(a,b),  for  the  function,  f(x),  and  for  the  variable  of  integration  (x).  The 
following  screen  shots  show  how  to  build  a  particular  integral.  The  insert 
cursor  is  first  located  in  the  lower  limit  of  integration,  enter  a  value  and  press 
the  right-arrow  key  (CD)  to  move  to  the  upper  limit  of  integration.  Enter  a 
value  in  that  location  and  press  CD  again  to  move  to  the  integrand  location. 
Type  the  integrand  expression,  and  press  once  more  to  move  to  the 
differential  place  holder,  type  the  variable  of  integration  in  that  location  and 
the  integral  is  ready  to  be  calculated. 


V-l)ds 

2 

EDIT  1  CURS  1  EIG  ■!  EVflL  |FflCTO|  SIMP 
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At  this  point,  you  can  press  (mh)  to  return  the  integral  to  the  stack,  which  will 
show  the  following  entry  (ALG  mode  shown): 


/■(2,5,s-^2-l,s> 


CflSCM  HELP 


This  is  the  general  format  for  the  definite  integral  when  typed  directly  into  the 
stack,  i.e.,  J  (lower  limit,  upper  limit,  integrand,  variable  of  integration) 

Pressing  [enter)  at  this  point  will  evaluate  the  integral  in  the  stack: 


5 

2 

36 

CHICHI  HELP  1         1         1  1 

The  integral  can  be  evaluated  also  in  the  Equation  Writer  by  selecting  the 
entire  expression  an  using  the  soft  menu  key  Bill. 

Step-by-step  evaluation  of  derivatives  and  integrals 

With  the  Step/Step  option  in  the  CAS  MODES  windows  selected  (see  Chapter 
1 ),  the  evaluation  of  derivatives  and  integrals  will  be  shown  step  by  step.  For 
example,  here  is  the  evaluation  of  a  derivative  in  the  Equation  Writer: 


■ 

■ 

Jx  -l.^Lx  J 

2.x^-2 

EDIT  1  CURS  1  EIG     EVflL  |FflCTO|  SIHP 
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Notice  the  application  of  the  chain  rule  in  the  first  step,  leaving  the  derivative 
of  the  function  under  the  integral  explicitly  in  the  numerator.  In  the  second 
step,  the  resulting  fraction  is  rationalized  (eliminating  the  square  root  from  the 
denominator),  and  simplified.  The  final  version  is  shov/n  in  the  third  step. 
Each  step  is  shown  by  pressing  the  SIj!!"!  menu  key,  until  reaching  the  point 
v/here  further  application  of  function  EVAL  produce  no  more  changes  in  the 
expression. 

The  follov/ing  example  shows  the  evaluation  of  a  definite  integral  in  the 
Equation  Writer,  step-by-step: 


EDIT   CURS   EIG  ■  EVflL  FflCTO  SIMP 


~2  '  ^  

S  +1 

Square  root 


National  fraction 
3 


A. 

Rat  ional 

f ract  ion 

a 

Rat  ional 

f ract  ion 

2 

2-s  

EDIT  I  CURS  I  EIG  ■!  EVHL  |FHCTO|  SIHP 


Notice  that  the  step-by-step  process  provides  information  on  the  intermediate 
steps  followed  by  the  CAS  to  solve  this  integral.  First,  CAS  identifies  a  square 
root  integral,  next,  a  rational  fraction,  and  a  second  rational  expression,  to 
come  up  with  the  final  result.    Notice  that  these  steps  make  a  lot  of  sense  to 
the  calculator,  although  not  enough  information  is  provided  to  the  user  on  the 
individual  steps. 
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Integrating  an  equation 

Integrating  an  equation  is  straightforward,  the  calculator  simply  integrates 
both  sides  of  the  equation  simultaneously,  e.g.. 


EDIT  1  CURS  1  EIG  -\  EVflL  |FflCTO|  SIMP 

EDIT  1  CURS  1  DIG  -\  EVflL  |FflCTD|  SIMP 

Techniques  of  integration 

Several  techniques  of  integration  can  be  implemented  in  the  calculators,  as 
shown  in  the  following  examples. 

Substitution  or  change  of  variables 

Suppose  we  want  to  calculate  the  integral  j^—j====dx  .  If  we  use  step-by- 
step  calculation  in  the  Equation  Writer,  this  is  the  sequence  of  variable 
substitutions: 


This  second  step  shows  the  proper  substitution  to  use,  u  =  . 


Int[u'*F<u>]  withi  u= 
Square  root 

Fx" 


Rational  fraction 

a 

Rational  fraction 


2-x 


llntLu'*l-:L?yJ  withi  u= 

Square  root 

Rational  fraction 
3 


EDIT  1  CURS  1 

DIG  ■!  EVflL 

IFflCTDI  SIMP 
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The  last  four  steps  show  the  progression  of  the  solution:  a  square  root, 
followed  by  a  fraction,  a  second  fraction,  and  the  final  result.  This  result  can 
be  simplified  by  using  function  EitEIii,  to  read: 


2-J3' 

EDIT  1  CURS  1  EIG     EVflL  |FflCTO|  SIMP 

Integration  by  parts  and  differentials 

A  differential  of  a  function  y  =  f(x),  is  defined  as  dy  =  f'(x)  dx,  where  f'(x)  is 
the  derivative  of  f(x).  Differentials  are  used  to  represent  small  increments  in 
the  variables.  The  differential  of  a  product  of  two  functions,  y  =  u(x)v(x),  is 
given  by  dy  =  u(x)dv(x)  +du(x)v(x),  or,  simply,  d(uv)  =  udv  ■  vdu.  Thus,  the 

integral  of  udv  =  d(uv)  -  vdu,  is  written  as  ^udv  =  ^d{uv)  —  ^vdu  .  Since  by 
the  definition  of  a  differential,  Jdy  =  y,  we  write  the  previous  expression  as 

^udv  -uv-  ^vdu . 

This  formulation,  known  as  integration  by  parts,  can  be  used  to  find  an 
integral  if  dv  is  easily  integrable.  For  example,  the  integral  jxe'^dx  can  be 
solved  by  integration  by  parts  if  we  use  u  =  x,  dv  =  e^dx,  since,  v  =  e''.  With 
du  =  dx,  the  integral  becomes  Ixe^dx  =  judv  =  uv  -  Jvdu  =  xe''  -  je^dx  =  xe"  -  e". 

The  calculator  provides  function  IBP,  under  the  CALC/DERIV&INTG  menu,  that 
takes  as  arguments  the  original  function  to  integrate,  namely,  u(X)*v'(X),  and 
the  function  v(X),  and  returns  u(X)*v(X)  and  -v(X)*u'(X).  In  other  words, 
function  IBP  returns  the  two  terms  of  the  right-hand  side  in  the  integration  by 
parts  equation.  For  the  example  used  above,  we  can  write  in  ALG  mode: 


IBp(x.e^e^) 


lEP   inTVK  LflPL  PREVfl  RISCH  SIGMfl 
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Thus,  we  can  use  function  IBP  to  provide  the  components  of  an  integration  by 
parts.  The  next  step  will  have  to  be  carried  out  separately. 


It  is  important  to  mention  that  the  integral  can  be  calculated  directly  by  using, 
for  example, 


IHTVX 


(X-l>e 


Integration  by  partial  fractions 

Function  PARTFRAC,  presented  in  Chapter  5,  provides  the  decomposition  of  a 
fraction  into  partial  fractions.  This  technique  is  useful  to  reduce  a  complicated 
fraction  into  a  sum  of  simple  fractions  that  can  then  be  integrated  term  by 
term.  For  example,  to  integrate 


X'  +5 


-dX 


we  can  decompose  the  fraction  into  its  partial  component  fractions,  as  follows: 


PflRTFRflC 


x'^+2.X^+X^ 
X^    ^    (X.D^  ^-^^ 


PflRTFRflC 


H     3  a 

•A  *2--A  *V. 


13 


inTVKtflnsd)) 

j.K^-a.K+-|-10.Ln(K)+-jj^+13.Ln(Ki 


IRR   IflTVX  LflF-L  F-REVfl  RI^CH^IGHflH  IRP   inTVX  LflRL  RREVfl  RI^CH^IGHfl 


The  direct  integration  produces  the  same  result,  with  some  switching  of  the 
terms  (Rigorous  mode  set  in  the  CAS  -  see  Chapter  2| 


inTVH(flnj(i» 

^.K^-a.K+-|-iD.Ln(IKI)+-jjjj+13.Ln(|t 


inrvK 


K^5 


H     3  a 


j.K^-a.K+13.Ln(IK+ll)+-(10.Ln(IKIJ)-| 


t^KIP  SKIP-H  H)EL   DEL-f  DEL  L  IflS 
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Improper  integrals 

These  are  integrals  with  infinite  limits  of  integration.  Typically,  an  improper 
integral  is  dealt  with  by  first  calculating  the  integral  as  a  limit  to  infinity,  e.g., 

t/x     , .  dx 

^  =  lim  —r-. 


Using  the  calculator,  we  proceed  as  follows: 


1 

H)EL   DEL-f  DEL  L  inS  ■ 

6-1 

:  limtRHStD) 

1 

+^KIP|SKIPH  H)EL  1  DEL-f|DEL 

L|  in^  ■ 

Alternatively,  you  can  evaluate  the  integral  to  infinity  from  the  start,  e.g., 


Integration  with  units 

An  integral  can  be  calculated  with  units  incorporated  into  the  limits  of 
integration,  as  in  the  example  shown  below  that  uses  ALG  mode,  with  the 
CAS  set  to  Approx  mode.  The  left-hand  side  figure  shows  the  integral  typed 
in  the  line  editor  before  pressing  [inter]  .    The  right-hand  figure  shows  the  result 
afte 


r  pressing 


X  dx 

.333333333333_mm^ 
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If  you  enter  the  integral  with  the  CAS  set  to  Exact  mode,  you  will  be  asked  to 
change  to  Approx  mode,  however,  the  limits  of  the  integral  will  be  shown  in  a 
different  format  as  shown  here: 


M_[vim 


2  . 

X  dx 


0'l_[vim 

■  333333333333-rvirvi' 

These  limits  represent  lxl_mm  and  Oxl_mm,  which  is  the  same  as  l_mm  and 
0_mm,  as  before.  Just  be  aware  of  the  different  formats  in  the  output. 

Some  notes  in  the  use  of  units  in  the  limits  of  integrations: 
1  -  The  units  of  the  lower  limit  of  integration  will  be  the  ones  used  in  the  final 
result,  as  illustrated  in  the  two  examples  below: 


l_min 


t^'  dt 


71999. 6666667_s- 


2  -  Upper  limit  units  must  be  consistent  with  lower  limit  units.  Otherwise,  the 


3  -  The  integrand  may  have  units  too.  For  example: 


ri-yr 

r  dr 

l.m 

'1. 

X'l_sdx 

0. 

.5_s 

•3 

1. 

<iy. 

2 

.HD5HS51D31Dg.-i= 

■EH 

4  -  If  both  the  limits  of  integration  and  the  integrand  have  units,  the  resulting 
units  are  combined  according  to  the  rules  of  integration.  For  example. 
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(wl_s)  dw 

1-9 

2.  33333333333_[9^'S^ 


t^KIP  SKIPH  H)EL   DEL-f  DEL  L  inS  ■ 


10_S 


0_S 


10_^+5_^.tdt 

s 

350_cm 


Infinite  series 

00 

An  infinite  series  has  the  form  ^^h{n){x  —  a)"  .  The  infinite  series  typically 

n=0,l 

starts  with  indices  n  =  0  or  n  =  1 .    Each  term  in  the  series  has  a  coefficient 
h(n)  that  depends  on  the  index  n. 

Taylor  and  Maclaurin's  series 

A  function  f(x)  can  be  expanded  into  an  infinite  series  around  a  point  x=Xo  by 
using  a  Taylor's  series,  namely, 

CO     /■(«)/-„  \ 

where  P"'(x)  represents  the  n-th  derivative  of  f(x)  with  respect  to  x,  P°'(x)  =  f(x). 
If  the  value  Xg  is  zero,  the  series  is  referred  to  as  a  Maclaurin's  series,  i.e., 

Taylor  polynomial  and  reminder 

In  practice,  we  cannot  evaluate  all  terms  in  an  infinite  series,  instead,  we 
approximate  the  series  by  a  polynomial  of  order  k,  P|<(x),  and  estimate  the 
order  of  a  residual,  Rk(x),  such  that 
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«=0  «=*+!  ^- 

i.e.,  /(x)  =  /',(x)  +  i?,(x). 

The  polynomial  P|<(x)  is  referred  to  as  Taylor's  polynomial.   The  order  of  the 
residual  is  estimated  in  terms  of  a  small  quantity  h  =  x-Xq,  i.e.,  evaluating  the 
polynomial  at  a  value  of  x  very  close  to  Xq.  The  residual  if  given  by 

where  ^  is  a  number  near  x  =  Xq.  Since  ^  is  typically  unknown,  instead  of  an 
estimate  of  the  residual,  we  provide  an  estimate  of  the  order  of  the  residual  in 
reference  to  h,  i.e.,  we  say  that  R|,(x)  has  an  error  of  order  h"^\  or  R  «  0(h''^^). 
If  h  is  a  small  number,  say,  h«l,  then  h^*^  will  be  typically  very  small,  i.e., 
h^'^^«h^«  ...«  h  «  1 .  Thus,  for  x  close  to  Xq,  the  larger  the  number  of 
elements  in  the  Taylor  polynomial,  the  smaller  the  order  of  the  residual. 

Functions  TAYLR,  TAYLRO,  and  SERIES 

Functions  TAYLR,  TAYLRO,  and  SERIES  are  used  to  generate  Taylor 
polynomials,  as  well  as  Taylor  series  with  residuals.   These  functions  are 
available  in  the  CALC/LIMITS&SERIES  menu  described  earlier  in  this  Chapter. 

Function  TAYLORO  performs  a  Maclaurin  series  expansion,  i.e.,  about  X  =  0, 
of  an  expression  in  the  default  independent  variable,  VX  (typically  'X').  The 
expansion  uses  a  4-th  order  relative  power,  i.e.,  the  difference  between  the 
highest  and  lowest  power  in  the  expansion  is  4.  For  example, 


:TRYLOR0(SIH™ 


DIVPCl  liH  |£ERIE|TAYLO|THYLR|  CHLC 


:  TRYLOR0[e 

1  2 

^■X  +X+1 

CHICHI  HELP  1         1         1  1 
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Function  TAYLR  produces  a  Taylor  series  expansion  of  a  function  of  any 
variable  x  about  a  point  x  =  a  for  the  order  k  specified  by  the  user.  Thus,  the 
function  has  the  format  TAYLR(f(x-a),x,k).  For  example, 


TRYLr[sIh[s~],s,6] 
1 


DIVPC    LiH  ^ERIE  THYLO  THYLR  CHLC  HDIVPC    liH  ^ERIE  TAYLO  THYLR KHLC 


Function  SERIES  produces  a  Taylor  polynomial  using  as  arguments  the  function 
f(x)  to  be  expanded,  a  variable  name  alone  (for  Maclaurin's  series)  or  an 
expression  of  the  form  'variable  =  value'  indicating  the  point  of  expansion  of 
a  Taylor  series,  and  the  order  of  the  series  to  be  produced.    Function  SERIES 
returns  two  output  items  a  list  v/ith  four  items,  and  an  expression  for  h  =  x  -  a, 
if  the  second  argument  in  the  function  call  is  'x=a',  i.e.,  an  expression  for  the 
increment  h.  The  list  returned  as  the  first  output  object  includes  the  follov/ing 
items: 

1  -  Bi-directional  limit  of  the  function  at  point  of  expansion,  i.e.,  lim  f{x) 

2  ■  An  equivalent  value  of  the  function  near  x  =  a 

3  -  Expression  for  the  Taylor  polynomial 

4  -  Order  of  the  residual  or  remainder 

Because  of  the  relatively  large  amount  of  output,  this  function  is  easier  to 
handle  in  RPN  mode.    For  example: 


J- 

4: 

3:  SIH(X) 
l:  6 

3: 

jLimit:  1  Equiy: 1  Exp* 
^=  h=X-f 

DIVPCI  liH  |SERIE|TflYLO|TflYLR|  CflLC 

DIVPCI  liH  |SERIE|TflYLO|TflYLR|  CflLC 

Drop  the  contents  of  stack  level  1  by  pressing  [  4  J,  and  then  enter  to 
decompose  the  list.  The  results  are  as  follov^s: 
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4:  Limit:l 

3:  Equiy:l 

2"  f  —1     6  1 

■  Expans:[:^-h  +r^-h 

1  ■  f 

Remain:  Ih 


DIVPCl  LiH  |£ERIE|THYLO|THYLR|  CHLC 


4Expans:  ' -1^720*h-^6+ 
l/24*h-^4+-l/2*h-^2+l ' 


k^KIP|£KIP-H  ^EL  I  DEL-»|DEL  L|  in£  ■ 


In  the  right-hand  side  figure  above,  we  are  using  the  line  editor  to  see  the 
series  expansion  in  detail. 
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Chapter  14 

Multi-variate  Calculus  Applications 

Multi-variate  calculus  refers  to  functions  of  two  or  more  variables.  In  tfiis 
Chapter  we  discuss  the  basic  concepts  of  multi-variate  calculus  including 
partial  derivatives  and  multiple  integrals. 

Multi-variate  functions 

A  function  of  two  or  more  variables  con  be  defined  in  the  calculator  by  using 
the  DEFINE  function  (I  *i  jpf^  ).  To  illustrate  the  concept  of  partial  derivative, 
we  will  define  a  couple  of  multi-variate  functions,  f(x,y)  =  x  cos(y),  and  g(x,y,z) 

=  (x^+'y^Y''h\n(z),  as  follows: 


:  DEFIHECf  (x,y)=x.COS(y)') 
HOVRL 

:  DEFIHe[  9(x,y,z)=Jx^+y^.^ 
HdVflL 


+^KIP|SKIP-H  H)EL  I  DEL-f|DEL  L|  inS  ■ 


We  can  evaluate  the  functions  as  we  would  evaluate  any  other  calculator 
function,  e.g.. 


:f  1.2,31 

2.C0S(3) 

:  9(1 -2  J 

^1 

J5.f 

3    \    f    \  mi  \  PPHR  IGRPH^IHPFIT 

Graphics  of  two-dimensional  functions  are  possible  using  FastSD,  Wireframe, 
Ps-Contour,  Y-Slice,  Gridmap,  and  Pr-Surface  plots  as  described  in  Chapter 
12. 

Partial  derivatives 

Consider  the  function  of  two  variables  z  =  f(x,y),  the  partial  derivative  of  the 
function  with  respect  to  x  is  defined  by  the  limit 
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^  ^  ^:^^fix  +  h,y)-fix,y) 
dx  h 

Similarly, 

^  ^:^^f{x,y  +  k)-f{x,y) 
ay  k 
We  will  use  the  multi-variate  functions  defined  earlier  to  calculate  partial 
derivatives  using  these  definitions.  Here  are  the  derivatives  of  f(x,y)  with 
respect  to  x  and  y,  respectively: 


COS(y) 


MnS    PPflR  GRPHS  MPFIT 


ftx^y+k) 

COS(y) 

k 

-f(x,y)j 

-(X'SIHM) 

3  1 

PPflR  |GRPHS|MPFIT 

Notice  that  the  definition  of  partial  derivative  with  respect  to  x,  for  example, 
requires  that  we  keep  y  fixed  while  taking  the  limit  as  h^O.  This  suggest  o 
way  to  quickly  calculate  partial  derivatives  of  multi-variate  functions:  use  the 
rules  of  ordinary  derivatives  with  respect  to  the  variable  of  interest,  while 
considering  all  other  variables  as  constant.  Thus,  for  example, 

^  [x  cos{y))  =  cos{y),  ^  {x  cos{y))  =  -x  sin{y) , 
ox  oy 

which  are  the  same  results  as  found  with  the  limits  calculated  earlier. 
Consider  another  example, 

—  {yx^  +  JF^ )  =  2yx  +  0  =  2xy 

dx 

In  this  calculation  we  treat  y  as  a  constant  and  take  derivatives  of  the 
expression  with  respect  to  x. 

Similarly,  you  can  use  the  derivative  functions  in  the  calculator,  e.g.,  DERVX, 
DERIV,  d  (described  in  detail  in  Chapter  1  3)  to  calculate  partial  derivatives. 
Recall  that  function  DERVX  uses  the  CAS  default  variable  VX  (typically,  'X'), 


Page  14-2 


therefore,  with  DERVX  you  con  only  calculate  derivatives  v/ith  respect  to  X. 
Some  examples  of  first-order  partial  derivatives  are  shov^n  next: 


COS(y) 

 x-SIHtyl 

3   1   f   1  Mns 

1  PPHR  IGRPHflHPFIT 

:^(9(x.y.z)) 

  2-^ 

x-SIH(y) 

1^'^  'Simzl 

X  +y  

3   1   f   1  Mns 

PPflR  IGRPHSIMPFIT 

DERVx(x.Y^-Y^) 


DERVXtX'SIHtY+X)) 

C0S(X+Y>X+SIH(X+Y1| 


DERIv(s.t^-e^,t) 


s-2-\-^ 


CURL  DERIV  DERVX   DIV   FOURI  HE33  H  CURL  DERIV  DERVX   DIV   FDURI  HE33 


Higher-order  derivatives 

The  follov/ing  second-order  derivatives  can  be  defined 


d_fdf  \  d\f_ 
dxydx  J  dy^ 


d_ 

dy 


dydx 


dyydxj 


5V 
dxdy 


d_ 

dx 


The  last  tv/o  expressions  represent  cross-derivatives,  the  partial  derivatives 
signs  in  the  denominator  shows  the  order  of  derivation.  In  the  left-hand  side, 
the  derivation  is  taking  first  with  respect  to  x  and  then  with  respect  to  y,  and  in 
the  right-hand  side,  the  opposite  is  true.    It  is  important  to  indicate  that,  if  a 
function  is  continuous  and  differentiable,  then 


ay  _ 

dydx  dxdy 
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Third-,  fourth-,  and  higher  order  derivatives  are  defined  in  a  similar  manner. 


To  calculate  higher  order  derivatives  in  the  calculator,  simply  repeat  the 
derivative  function  as  many  times  as  needed.  Some  examples  are  shown 
below: 


0 

x-COS(y) 


ixliy 
iylix 


^f^tftx.y))) 


-SIH(y) 
-SIH(y) 


CURL  DERIV  DERVX   DIV   FOURI  HE££  H  CURL  DERIV  DERVX   DIV   FOURI  HE££ 


The  chain  rule  for  partial  derivatives 

Consider  the  function  z  =  f(x,y),  such  that  x  =  x(t),  y  =  y(t).  The  function  z 
actually  represents  a  composite  function  of  t  if  we  write  it  as  z  =  f[x(t),y(t)]. 
The  chain  rule  for  the  derivative  dz/dt  for  this  case  is  written  as 


dz     dz  dx    dz  dy 


+  ■ 


dv    dx  dv    dy  dv 


To  see  the  expression  that  the  calculator  produces  for  this  version  of  the  chain 
rule  use: 


^(z(x(t),y(t))) 
d  1  y(t  >d2z(x(t  ),y  tt  D+d  1  x(t  ► 


The  result  is  given  by  dly(t)-d2z(x(t),y(t))+dlx(t)  dlz(x(y),y(t)).  The  term  dly(t) 
is  to  be  interpreted  as  "the  derivative  of  y(t)  with  respect  to  the  1'*  independent 
variable,  i.e.,  t",  or  dly(t)  =  dy/dt.  Similarly,  dlx(t)  =  dx/dt.  On  the  other 
hand,  dl  z(x(t),y(t))  means  "the  first  derivative  of  z(x,y)  with  respect  to  the  first 
independent  variable,  i.e.,  x",  or  d  1  z(x(t),y(t))  =  8z/8x.  Similarly, 
d2z(x(t),y(t))  =  8z/dy.  Thus,  the  expression  above  is  to  be  interpreted  as: 


dz/dt  =  (dy/dt)-(5z/ey)  +  (dx/dt)-  (5z/5x). 
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Total  differential  of  a  function  z  =  z(x,y) 

From  the  last  equation,  if  we  multiply  by  dt,  we  get  the  total  differential  of  the 
function  z  =  z(x,y),  i.e.,  dz  =  {5z/9x)  dx  +  (9z/9y)  dy. 


A  different  version  of  the  chain  rule  applies  to  the  case  in  which  z  =  f(x,y),  x 
=  x(u,v),  y  =  y(u,v),  so  that  z  =  f[x(u,v),  y(u,v)].  The  following  formulas 
represent  the  chain  rule  for  this  situation: 

dz  _dz  dx  ^  dz  dy  dz  _dz  dx  ^  dz  dy 
du     dx  du    dy  du'       dv    dx  dv    dy  dv 

Determining  extrema  in  functions  of  two  variables 

In  order  for  the  function  z  =  f(x,y)  to  have  an  extreme  point  (extrema)  at  (x^yj, 
its  derivatives  di/dx  and  5f/9y  must  vanish  at  that  point.  These  are  necessary 
conditions.  The  sufficient  conditions  for  the  function  to  have  an  extreme  at 
point  (x„,yj  are  di/dx  =  0,  di/dy  =  0,  and  A  =  (S'f/Sx')-  [d^Vdy^yidVdxdy]^ 
>  0.  The  point  (x„,yo)  is  a  relative  maximum  if  d^i/8x^<  0,  or  a  relative 
minimum  if  d^{/8x^>  0.  The  value  A  is  referred  to  as  the  discriminant. 

If  A  =  (d^/dx^)-  (9^f/9y^)-[9^f/5x5y]^  <  0,  we  have  a  condition  known  as  a 
saddle  point,  where  the  function  would  attain  a  maximum  in  x  if  we  were  to 
hold  y  constant,  while,  at  the  same  time,  attaining  a  minimum  if  we  were  to 
hold  X  constant,  or  vice  versa. 


Example  1  -  Determine  the  extreme  points  (if  any)  of  the  function  f(X,Y)  =  X'^- 
3X-Y2+5.  First,  we  define  the  function  f(X,Y),  and  its  derivatives  fX(X,Y)  = 
di/dX,  fY(X,Y)  =  5f/5Y.  Then,  we  solve  the  equations  fX(X,Y)  =  0  and  fY(X,Y) 
=  0,  simultaneously: 


DEFinE('F(K,V)=K^-3.K-V^+5') 

HOVRLJ 


MnS    PPflR  GRPHS  MPFIT 


:^(F(K^V))^FV 

-O.VJ 

:SOLVE(CFK  FVD/CK 

V=DD  CK=-1  V=DD3 

MnS    PPflR  GRPHS 
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We  find  critical  points  at  (X,Y)  =  (1,0),  and  {X,Y)  =  (-1,0).  To  calculate  the 
discriminant,  we  proceed  to  calculate  the  second  derivatives,  fXX(X,Y)  = 
e^f/eX^,  fXY(X,Y)  =  e'f/eX/eY,  and  fYY(X,Y)  =  s'f/eY^. 


■^ULVLLLFA  r  1  Jj'LA    1  J'J 

CK=-1  V=DDI 

:^(RCL('FV'))^FVV 

-2 

^(RCL('FK'))^FKV 


FKK-FVV-FKV 


-(la.K) 


The  last  result  indicates  that  the  discriminant  is  A  =  -1  2X,  thus,  for  (X,Y)  =  (1 ,0), 
A  <0  (saddle  point),  and  for  (X,Y)  =  (-1,0),  A>0  and  d'OdX^KO  (relative 
maximum).  The  figure  below,  produced  in  the  calculator,  and  edited  in  the 
computer,  illustrates  the  existence  of  these  two  points: 


siddle  point 


Using  function  HESS  to  analyze  extrema 

Function  HESS  can  be  used  to  analyze  extrema  of  a  function  of  two  variables 
as  shown  next.  Function  HESS,  in  general,  takes  as  input  a  function  of  n 
independent  variables  ^x^,  x^,  ...,Xn)/  a  vector  of  the  functions  ['x/ 
'x2'...'x„'].  Function  HESS  returns  the  Hessian  matrix  of  the  function  ^,  defined 
as  the  matrix  H  =  [h;|]  =  [3^(|)/9Xi9X|],  the  gradient  of  the  function  with  respect 
to  the  n-variables,  grad  f  =  [  5(|)/5xi,  5(|)/5x2  ,  ...  9(|)/9xJ,  and  the  list  of 
variables  ['x/  V-X']. 
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Applications  of  function  HESS  are  easier  to  visualize  in  the  RPN  mode. 
Consider  as  on  example  the  function  (|)(X,Y,Z)  =  +  XY  +  XZ,  we'll  apply 
function  HESS  to  function  cj)  in  the  following  example.  The  screen  shots  show 


the  RPN 


stack  before  and  after  applying  function  HESS. 


5: 

4: 

3: 

2: 

l: 

[X  Y  Z] 

3  = 

4: 

3: 

\2  1  11 

1  e  e 

Li  e  eJ 

2: 

z2-y.+y+z  y  y.i 

l: 

[X  Y  Z] 

when  applied  to  a  function  of  two  variables,  the  gradient  in  level  2,  when 
made  equal  to  zero,  represents  the  equations  for  critical  points,  i.e.,  d^/dx-,  -- 
0,  while  the  matrix  in  level  3  represent  second  derivatives.  Thus,  the  results 
from  the  HESS  function  can  be  used  to  analyze  extrema  in  functions  of  two 
variables.  For  example,  for  the  function  f(X,Y)  =  X"^-3X-Y^+5,  proceed  as 
follows  in  RPN  mode: 


'X'^3-3*X-Y''2+5'  ['XVY']  Enter  function  and  variables 

HESS  Apply  function  HESS 

SOLVE  Find  critical  points 

[EVALj  Decompose  vector 

'si '  IsTo*]  's2'  [sToy]  Store  critical  points 

The  variables  si  and  s2,  at  this  point,  contain  the  vectors  ['X=-l  ','Y=0]  and 
['X=l  ','Y=0],  respectively.  The  Hessian  matrix  is  at  level  1  at  this  point. 


H'(W) 

BGSSSSSSSUBSTCS^^ 


Store  Hessian  matrix 
Substitute  si  into  H 


The  resulting  matrix  A  has  a,,  elements  a^  =  d^^/dX^  =  -6.,  =  d^^/dX"^ 
2.,  and  012  =  021  =  d^^/dXdY  =  0.  The  discriminant,  for  this  critical  point 
si  (-1 ,0)  is  A  =  (5V9x>  (d'{/dy')Wdxdy]^  =  (-6.)(-2.)  =  1 2.0  >  0.  Since 
d^^/dX^  <0,  point  si  represents  a  relative  maximum. 

Next,  we  substitute  the  second  point,  s2,  into  H: 

Substitute  s2  into  H 


SUBSTCgD=^«lf 
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The  resulting  matrix  has  elements  Oi]  =  d^^/d)^  =  6.,  022  =  d^^/dX^  =  -2., 
and  0,2=021=  d^(^/dXdY=  0.  The  discriminant,  for  this  critical  point  s2(l  ,0) 
is  A  =  (d'i/dx^y  {d'{/8y')-[d'\/8xdyY  =  (6.)(-2.)  =  -1  2.0  <  0,  indicoting  o 
soddle  point. 

Multiple  integrals 

A  physical  interpretation  of  on  ordinary  integral,     f{x)dx,  is  the  area 

under  the  curve  y  =  f(x)  and  abscissas  x  =  a  and  x  =  b.    The  generalization 
to  three  dimensions  of  an  ordinary  integral  is  a  double  integral  of  a  function 
f(x,y)  over  a  region  R  on  the  x-y  plane  representing  the  volume  of  the  solid 
body  contained  under  the  surface  f(x,y)  above  the  region  R.   The  region  R 
can  be  described  as  R  =  {a<x<b,  f(x)<y<g(x)}  or  as  R  =  {c<y<d,  r(y)<x<s(y)}. 
Thus,  the  double  integral  can  be  v/ritten  as 

\\(l){x,y)dA=         ^(x,y)dydx=  ^(x,y)dydx 

J  J  Ja  Jf(x)  Jc  Jr(y) 

R 


Calculating  a  double  integral  in  the  calculator  is  straightforward.  A  double 
integral  can  be  built  in  the  Equation  Writer  (see  example  in  Chapter  2).  An 
example  follov/s.  This  double  integral  is  calculated  directly  in  the  Equation 
Writer  by  selecting  the  entire  expression  and  using  function  lll-UJ.  The  result 
is  3/2.    Step-by-step  output  is  possible  by  setting  the  Step/Step  option  in  the 
CAS  MODES  screen. 


2 

^x-Hydy  dx4 

1 

EDIT  1  CURS 

1  EIG  ■!  EVflL  IFflCTOI  SIMP 
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3'X  2-x+l 

2  2 
Rational  fraction 

2 


IS 

EDIT  1  CURS  1  EIG  -\  EVflL  |FflCTO|  SIMP 

3'X  2-X+ 

2  2 

Rat  ional 

f ract  ion 

2 

Rat  ional 

f ract  ion 

Jacobian  of  coordinate  transformation 

Consider  the  coordinate  transformation  x  =  x(u,v),  y  =  y(u,v).  The  Jacobian  of 
this  transformation  is  defined  as 


J  1=  det(  J)  =  det 


dx^ 

det 

du 

dv 

dy_ 

When  calculating  an  integral  using  such  transformation,  the  expression  to  use 
is  ^^^{x,y)dydx  =  ||^[x(m,v),  j^(m,v)]  |  J  \  dudv ,  where  R'  is  the  region  R 

R  R' 

expressed  in  (u,v)  coordinates. 

Double  integral  in  polar  coordinates 

To  transform  from  polar  to  Cartesian  coordinates  we  use  x(r,0)  =  r  cos  0,  and 
y(r,  0)  =  r  sin  9.  Thus,  the  Jacobian  of  the  transformation  is 

dx  dx 

=  ^^^^^^    ~ ^ ' ^^^^^^ 
dy_    dy_     sm(0)     r -008(0) 

dr  dO 

With  this  result,  integrals  in  polar  coordinates  are  written  as 


=  r 
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where  the  region  R'  in  polar  coordinates  is  R'  =  {a  <  0  <  p,  f(6)  <  r  <  g(0)}. 


Double  integrals  in  polar  coordinates  can  be  entered  in  the  calculator,  making 
sure  that  the  Jocobian  |J  |  =  r  is  included  in  the  integrand.  The  following  is  an 
example  of  a  double  integral  calculated  in  polar  coordinates,  shown  step-by- 
step: 


3t 

National  fraction 
- 


Linearizing 


■ 

32 

■ 

EDIT  1  CURS  1  EIG  ■!  EVflL  |FflCTO|  SIMP 

-1 

edT^urs 

FflOORlMr 
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Chapter  1 5 

Vector  Analysis  Applications 

In  this  Chapter  we  present  a  number  of  functions  from  the  CALC  menu  that 
apply  to  the  analysis  of  scalar  and  vector  fields.   The  CALC  menu  was 
presented  in  detail  in  Chapter  13.  In  particular,  in  the  DERIV&INTEG  menu 
we  identified  a  number  of  functions  that  have  applications  in  vector  analysis, 
namely,  CURL,  DIV,  HESS,  LAPL.  For  the  exercises  in  this  Chapter,  change 
your  angle  measure  to  radians. 


Definitions 

A  function  defined  in  a  region  of  space  such  as  (|)(x,y,z)  is  known  as  a  scalar 
field,  examples  are  temperature,  density,  and  voltage  near  a  charge.  If  the 
function  is  defined  by  a  vector,  i.e.,  F(x,y,z)  =  f{x,y,z)i+g{x,y,z)|+h(x,y,z)k,  it 
is  referred  to  as  a  vector  field. 


The  following  operator,  referred  to  as  the  'del'  or  'nabia'  operator,  is  a  vector- 
based  operator  that  can  be  applied  to  a  scalar  or  vector  function: 

v[]=/4[]+i4[i+*4[] 

ox  oy  oz 

When  this  operator  is  applied  to  a  scalar  function  we  can  obtain  the  gradient 
of  the  function,  and  when  applied  to  a  vector  function  we  can  obtain  the 
divergence  and  the  curl  of  that  function.  A  combination  of  gradient  and 
divergence  produces  another  operator,  called  the  Laplacian  of  a  scalar 
function.  These  operations  are  presented  next. 

Gradient  and  directional  derivative 

The  gradient  of  a  scalar  function  (|)(x,y,z)  is  a  vector  function  defined  by 

jj.    ^  J.     ■  .  d<l)  ^ 

grad^  =  V^  =  /-  —  +  J  ■  —  +  k-  — 

dx        dy  dz 

The  dot  product  of  the  gradient  of  a  function  with  a  given  unit  vector 
represents  the  rate  of  change  of  the  function  along  that  particular  vector.  This 
rate  of  change  is  called  the  directional  derivative  of  the  function,  D„(|)(x,y,z)  = 
u»V(|). 
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At  any  particular  point,  the  maximum  rate  of  change  of  the  function  occurs  in 
the  direction  of  the  gradient,  i.e.,  along  a  unit  vector  u  =  Vcj)/ 1  V(|)  | . 

The  value  of  that  directional  derivative  is  equal  to  the  magnitude  of  the 
gradient  at  any  point  D^a^^(x,y,z)  =  V(|)  "Vcj)/ 1  V(|)  |  =  |  V(j)  | 

The  equation  (|)(x,y,z)  =  0  represents  a  surface  in  space.  It  turns  out  that  the 
gradient  of  the  function  at  any  point  on  this  surface  is  normal  to  the  surface. 
Thus,  the  equation  of  a  plane  tangent  to  the  curve  at  that  point  can  be  found 
by  using  a  technique  presented  in  Chapter  9. 

The  simplest  way  to  obtain  the  gradient  is  by  using  function  DERIV,  available 
in  the  CALC  menu,  e.g., 

[:   DERIVtX-^2+Z*Y-^2,  [X, 
V,Z]> 

C£*X,Z*(2*Y>,Y-^£] 


A  program  to  calculate  the  gradient 

The  following  program,  v/hich  you  can  store  into  variable  GRADIENT,  uses 
function  DERIV  to  calculate  the  gradient  of  a  scalar  function  of  X,Y,Z. 
Calculations  for  other  base  variables  will  not  work.  If  you  work  frequently  in 
the  (X,Y,Z)  system,  however,  this  function  will  facilitate  calculations: 

«  X  Y  Z  3  ^ARRY  DERIV  » 

Type  the  program  while  in  RPN  mode.  After  switching  to  ALG  mode,  you  can 
call  the  function  GRADIENT  as  in  the  following  example: 


GRRD I EHT  (.  X-^2+Y-^2+Z-^2i 
[£*X,£*Y,£*Z] 


Using  function  HESS  to  obtain  the  gradient 

The  function  HESS  can  be  used  to  obtain  the  gradient  of  a  function  as  shown 
next.  As  indicated  in  Chapter  14,  function  HESS  takes  as  input  a  function  of 
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n  independent  variables  (|)(xi,  X2,  ...,Xn)/  cind  a  vector  of  the  functions  ['x/ 
'x2'...'Xn'].  Function  HESS  returns  the  Hessian  matrix  of  the  function  ^,  defined 
OS  the  matrix  H  =  [hi|]  =  [9(j)/9Xi9Xi],  the  gradient  of  the  function  with  respect  to 
the  n-variables,  grad  f  =  [  d^/dx-^,  d^/dx^  ,  ••■  Sif/dx^,  and  the  list  of 
variables  ['x/  'x2'...'Xn'].  Consider  as  an  example  the  function  (t)(X,Y,Z)  = 
+  XY  +  XZ,  v^e'll  apply  function  HESS  to  this  scalar  field  in  the  following 
example  in  RPN  mode: 


4: 

l: 

[X  Y  Z] 

3: 

4: 

3: 

\2  1  11 

1  e  e 

Li  e  eJ 

2: 

[2.X+Y+Z  X  X] 

l: 

[X  Y  Z] 

Thus,  the  gradient  is  [2X+Y+Z,  X,  X].  Alternatively,  one  can  use  function 
DERIV  as  follows:  DERIV(X'^2+X*Y+X*Z,[X,Y,Z]),  to  obtain  the  same  result. 

Potential  of  a  gradient 

Given  the  vector  field,  F(x,y,z)  =  f(x,y,z)i+g(x,y,z)i+h(x,y,z)k,  if  there  exists  a 
function  (|)(x,y,z),  such  that  f  =  dif/dx,  g  =  d^/dy,  and  h  =  B^/dz.,  then  (|)(x,y,z) 
is  referred  to  as  the  potential  function  for  the  vector  field  F.  It  follows  that  F  = 
grad  ^  =  V^. 


The  calculator  provides  function  POTENTIAL,  available  through  the  command 
catalog  ((j^l  cat  ),  to  calculate  the  potential  function  of  a  vector  field,  if  it 
exists.  For  example,  if  F(x,y,z)  =  xi  +  yj  +  zk,  applying  function  POTENTIAL 
we  find: 


POTEHTIRLtCxy  z].[x  y  z:>i 
2        2  2 


Since  function  SQ(x)  represents  x^,  this  results  indicates  that  the  potential 
function  for  the  vector  field  F(x,y,z)  =  xi  +  yj  +  zk,  is  (|)(x,y,z)  =  (x^+y^+z^)/2. 


Notice  that  the  conditions  for  the  existence  of  (|)(x,y,z),  namely,  f  =  d^/dx,  g  = 
d^/dy,  and  h  =  d^/dz,  are  equivalent  to  the  conditions:  5f/9y  =  dg/dx,  di/dz 
=  dh/dx,  and  dg/dz  =  dh/dy.  These  conditions  provide  a  quick  way  to 
determine  if  the  vector  field  has  an  associated  potential  function.  If  one  of  the 
conditions  d{/dy  =  dg/dx,  di/dz  =  dh/dx,  dg/dz  =  dh/dy,  fails,  a  potential 
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function  (|)(x,y,z)  does  not  exist.  In  such  case,  function  POTENTIAL  returns  an 
error  message.    For  example,  the  vector  field  F(x,y,z)  =  (x+y)i  +  (x-y+z)j  + 
xzk,  does  not  have  a  potential  function  associated  with  it,  since,  5f/9z  ^ 
5h/5x.  The  calculator  response  in  this  case  is  shown  below: 


POTENT  I  RL(CX+Y  X-Y+Z  XH 
POTENT I RL  t [ X+V , X-Y+Z , 
^i*Z],  CX,Y,Z]> 


:PC 
:PC 

A  POTENTIRL 
Error: 

Bad  Rrgument 
Value 

:  X^ 
1  X^ 
ue" 

Bad  Rrgument  Va! 

+^KIP|SKIP^  H)EL  1  DEL-f|DEL  L| 

ins  ■ 

Divergence 

The  divergence  of  a  vector  function,  F(x,y,z)  =  f(x,y,z)i+g(x,y,z)j+h(x,y,z)k, 
is  defined  by  taking  a  "dot-product"  of  the  del  operator  with  the  function,  i.e., 

dx    dy  8z 

Function  DIV  can  be  used  to  calculate  the  divergence  of  a  vector  field.  For 
example,  for  F{X,Y,Z)  =  [XY,X^+Y^+Z^,YZ],  the  divergence  is  calculated,  in 
ALG  mode,  as  follows: 


Dlv([x.Y  X^+Y^+Z^  Y'ZllX^ 
Y+2.Y+Y 


Laplacian 

The  divergence  of  the  gradient  of  a  scalar  function  produces  an  operator 
called  the  Laplacian  operator.  Thus,  the  Laplacian  of  a  scalar  function  (|)(x,y,z) 
is  given  by 

dx      dx  dx 

The  partial  differential  equation  V^cj)  =  0  is  known  as  Laplace's  equation. 
Function  LAPL  can  be  used  to  calculate  the  Laplacian  of  a  scalar  function.  For 
example,  to  calculate  the  Laplacian  of  the  function  (|)(X,Y,Z)  =  (X^+Y^)cos(Z), 
use: 
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LRPL<<X-^£+Y-^£)*COS<Z 

2*C0StZ>+<2*C0S<Z>+<X 
2+Y-^£>*-C0S(Z>> 

Curl 

The  curl  of  a  vector  field  F(x,y,z)  =  f(x,y,z)i+g(x,y,z)j+h(x,y,z)k,  is  defined  by 
a  "cross-product"  of  the  del  operator  with  the  vector  field,  i.e.. 


curie  =  V  X  F  = 


J 


dx 


[] 


dy 


[] 


dz 


[] 


f(x,y,z)    g(x,y,z)  h(x,y,z) 


=  i  ^  +j 


dy  dz 


df    d}i\   .  [ dh  dg^ 
+  k 


dz  dx 


dy  dz 


The  curl  of  vector  field  can  be  calculated  v/ith  function  CURL.  For  example, 
for  the  function  F(X,Y,Z)  =  [XY ,X'^+Y^+Z\YZ],  the  curl  is  calculated  as  follov/s: 


:  CURl([x.Y  X^+Y^+Z^  Y^zIl^ 
[Z-2.Z  0  2-y.-ki 


Irrotational  fields  and  potential  function 

In  an  earlier  section  in  this  chapter  we  introduced  function  POTENTIAL  to 
calculate  the  potential  function  (|)(x,y,z)  for  a  vector  field,  F(x,y,z)  =  f(x,y,z)i+ 
g(x,y,z)j+  h(x,y,z)k,  such  that  F  =  grad  (|)  =  V(|).   We  also  indicated  that  the 
conditions  for  the  existence  of  (j),  were:  di/dy  =  dg/dx,  5f/5z  =  6h/8x,  and 
5g/5z  =  5h/6y.  These  conditions  are  equivalent  to  the  vector  expression 

curl  F  =  VxF  =  0. 


A  vector  field  F(x,y,z),  with  zero  curl,  is  known  as  an  irrotational  field.  Thus, 
we  conclude  that  a  potential  function  (|)(x,y,z)  always  exists  for  an  irrotational 
field  F(x,y,z). 
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As  an  example,  in  an  earlier  example  we  attempted  to  find  a  potential 
function  for  tfie  vector  field  F(x,y,z)  =  (x+y)i  +  (x-y+z)j  +  xzk,  and  got  an  error 
message  back  from  function  POTENTIAL.  To  verify  that  this  is  a  rotational 
field  (i.e.,  VxF  ^  0),  we  use  function  CURL  on  this  field: 


CURL([X+Y  X-Y+Z  X'Z],[X  > 
 [-1  -Z  S] 


On  the  other  hand,  the  vector  field  F(x,y,z)  =  xi  +  yj  +  zk,  is  indeed 


ov/: 

:CURL([X+V  X- 

-v+z 

X.Z],[X  > 

:CURL([X  V  Z] 

[X  Y 

ZD 

[0  0  0] 

+^KIP|SKIP^  H)EL 

DEL-f 

DEL  L|in£> 

Vector  potential 

Given  a  vector  field  F(x,y,z)  =  f(x,y,z)i+g(x,y,z)i+h(x,y,z)k,  if  there  exists  a 
vector  function  <l)(x,y,z)  =  (t)(x,y,z)i+\|/(x,y,z)j+ri(x,y,z)k,  such  that  F  =  curl  3)  = 
Vx  O,  then  function  0(x,y,z)  is  referred  to  as  the  vector  potential  of  F(x,y,z). 

The  calculator  provides  function  VPOTENTIAL,  available  through  the 
command  catalog  ([  r»  J  cat  ),  to  calculate  the  vector  potential,  0(x,y,z),  given 
the  vector  field,  F(x,y,z)  =  f(x,y,z)i+g(x,y,z)j+h(x,y,z)k.  For  example,  given 
the  vector  field,  F(x,y,z)  =  -(yi+zj+xk),  function  VPOTENTIAL  produces 


:VPOTEHTIRL(-[y  z  xJ 


z  x]..[x  L> 

+Z'X 


i.e.,  <l)(x,y,z)  =  -xV2i  +  (-yV2+zx)k. 

It  should  be  indicated  that  there  is  more  than  one  possible  vector  potential 
functions  O  for  a  given  vector  field  F.  For  example,  the  following  screen  shot 
shows  that  the  curl  of  the  vector  function  0),  =  [X2+Y2+Z^XYZ,X+Y+Z]  is  the 
vector  F  =  Vx  (Dj  =  [1-XY,2Z-1,ZY-2Y].  Application  of  function  VPOTENTIAL 
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produces  the  vector  potential  function      =  [0,  ZYX-2YX,  Y-(2ZX-X)],  which  is 
different  from  Oi.  The  last  command  in  the  screen  shot  shows  that  indeed  F  = 
Vx        Thus,  a  vector  potential  function  is  not  uniquely  determined. 


:  CURl([x  +Y  +Z   X'Y'Z  X+? 

[l-X'Y  2-Z-l  Z-Y-2-Y1 
:VP0TEHTIRL(RHS(1).[X  Y  2* 
[0  Z.Y.X-2.Y-X  Y-(2.Z.X-X)] 
:CURL(flHS(l),[X  Y  Z]5 

[l-Y'X  Z-2-1  Y.Z-Y.2] 


The  components  of  the  given  vector  field,  F(x,y,z)  =  f(x,y,z)i+g(x,y,z)j 
+h{x,y,z)k,  and  those  of  the  vector  potential  function,  ^{x,y,z)  = 
(|)(x,y,z)i+\|/(x,y,z)|+r|(x,y,z)k,  are  related  by  f  =  dr]/dy  -  8\\i/dx,  g  =  d^/dz  - 
5ri/5x,  and  h  =  5\|//5x  -  5(|)/5y. 

A  condition  for  function  $(x,y,z)  to  exists  is  that  div  F  =  V«F  =  0,  i.e.,  9f/5x  + 
dg/dy  +  di/dz  =  0.  Thus,  if  this  condition  is  not  satisfied,  the  vector  potential 
function  4)(x,y,z)  does  not  exist.  For  example,  given  F  =  [X+Y,X-Y,Z'^2], 
function  VPOTENTIAL  returns  an  error  message,  since  function  F  does  not 
satisfy  the  condition  V»F  =  0: 


vpotehtirl([x+y  X-Y  z  i 

4P0TEHT I RL  t [ X+Y , X-Y ,  Z 
■2], [X,Y,Z]> 


t^KIP  SKIP-H  H)EL   DEL-f  DEL  L  inS 


VF 


A  vpotehtirl 

Error: 

Bad  Rr9ument 


.21 


"Bad  Rrgument  Value" 


t^KIP  SKIPH  H)EL   DEL-f  DEL  L  IDS  i 


The  condition  V«F    0  is  verified  in  the  following  screen  shot: 


:  DI v([x+Y  X-Y  Z^llX  Y  Z])  , 
1+-1+2.Z 
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Chapter  1 6 
Differential  Equations 

In  this  Chapter  we  present  examples  of  solving  ordinary  differential  equations 
(ODE)  using  calculator  functions.  A  differential  equation  is  an  equation 
involving  derivatives  of  the  independent  variable.  In  most  cases,  v/e  seek  the 
dependent  function  that  satisfies  the  differential  equation. 

Basic  operations  with  differential  equations 

In  this  section  we  present  some  uses  of  the  calculator  for  entering,  checking 
and  visualizing  the  solution  of  ODEs. 

Entering  differential  equations 

The  key  to  using  differential  equations  in  the  calculator  is  typing  in  the 
derivatives  in  the  equation.  The  easiest  v/ay  to  enter  a  differential  equation  is 
to  type  it  in  the  equation  v^riter.  For  example,  to  type  the  follov^ing  ODE; 
(x-1  )-(dy(x)/dx)^  +  2-x-y(x)  =  e"  sin  x,  use: 

(53(^iM)(jT](gCT](i  (d™)SD(SCDCD  CZI1CX3  CDCDGEDCX3CHD 

CZD=  C5D^  (^C5D  (3  CE)CXDC»D(4^C5D(3 

The  derivative  dy/dx  is  represented  by  9x(y(x))  or  by  diy(x).  For 
solution  or  calculation  purposes,  you  need  to  specify  y(x)  in  the  expression, 
i.e.,  the  dependent  variable  must  include  its  independent  variable(s)  in  any 
derivative  in  the  equation. 

You  can  also  type  an  equation  directly  into  the  stack  by  using  the  symbol  8  in 
the  derivatives.  For  example,  to  type  the  following  ODE  involving  second- 
order  derivatives:  d^u(x)/dx^  +  3-u(x)-(du(x)/dx)  +  u(x)^  =  l/x,  directly  into 
the  screen,  use: 

(4™]CZD(3CDCZDCri]  <j.  (^™)C5D(S]C3  U  

(^CS(g  CDCD  CTD(^CS(3QD  'J—  (4™)C5D(21CD  CEDCX) 
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The  result  is  '9x  (5x  (u  (x) ) ) +3*u  (x)  *5x  (u  (x) ) +u^2=i/x  '.  This  format 
shows  up  in  the  screen  when  the  _Textbook  option  in  the  display  setting 
((MODfJIulEM)  is  not  selected.  Press  ^3?  to  see  the  equation  in  the  Equation 
Writer. 

An  alternative  notation  for  derivatives  typed  directly  in  the  stack  is  to  use  'dl' 
for  the  derivative  with  respect  to  the  first  independent  variable,  'd2'  for  the 
derivative  with  respect  to  the  second  independent  variable,  etc.  A  second- 
order  derivative,  e.g.,  dWdt^,  where  x  =  x(t),  would  be  written  as  'dldlx(t)', 
while  (dx/dt)2  would  be  written  'dlx(t)''2'.  Thus,  the  PDE  SV^t^  -  gKv)- 
{d^y/dx^)^  =  r(x,y),  would  be  written,  using  this  notation,  as  'd2d2y(x,t)- 
g(x,y)*dldly{x,t)'^2=r(x,y)'. 

The  notation  using 'd'  and  the  order  of  the  independent  variable  is  the 
notation  preferred  by  the  calculator  when  derivatives  are  involved  in  a 
calculation.  For  example,  using  function  DERIV,  in  ALG  mode,  as  shown  next 
DERIV('x*f(x,t)+g(t,y)  =  h(x,y,t)',t),  produces  the  following  expression: 
'x*d2f  (x,  t)  +dlg  (t,  y)  =d3h  (x,  y,  t) '.  Translated  to  paper,  this 
expression  represents  the  partial  differential  equation  x-(9f/5t)  +  5g/5t  =  5h/5t. 

Because  the  order  of  the  variable  t  is  different  in  f(x,t),  g(t,y),  and  h(x,y,t), 
derivatives  with  respect  to  t  have  different  indices,  i.e.,  d2f(x,t),  dlg(t,y),  and 
d3h(x,y,t).  All  of  them,  however,  represent  derivatives  with  respect  to  the 
same  variable. 

Expressions  for  derivatives  using  the  order-of-variable  index  notation  do  not 
translate  into  derivative  notation  in  the  equation  writer,  as  you  can  check  by 
pressing  '^V?  while  the  last  result  is  in  stack  level  1 .  However,  the  calculator 
understands  both  notations  and  operates  accordingly  regarding  of  the 
notation  used. 

Checking  solutions  in  the  calculator 

To  check  if  a  function  satisfy  a  certain  equation  using  the  calculator,  use 
function  SUBST  (see  Chapter  5)  to  replace  the  solution  in  the  form  'y  =  f(x)'  or 
'y  =  f(x,t)',  etc.,  into  the  differential  equation.  You  may  need  to  simplify  the 
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result  by  using  function  EVAL  to  verify  the  solution.  For  example,  to  check  that 
u  =  A  sin  cOot  is  a  solution  of  the  equation  d^u/dt^  +  cOo^  u  =  0,  use  the 
following: 

In  ALG  mode; 

SUBST('at(et(u(t)))+  (o0^2*u(\)  =  0'/u(t)=A*SIN  (raO^t)')  ^ 
EVAL(ANS(1))(^ 

In  RPN  mode: 

'5t{et(u(t)))+  coO'^2*u(t)  =  0'        'u(t)=A*SIN  (coO*t)' 
SI.JBST  E'v'RL. 

The  result  is  '0=0'. 

For  this  example,  you  could  also  use:  '5t(5t(u(t))))+  coO'^2*u{t)  =  0'  to  enter  the 
differential  equation. 

Slope  field  visualization  of  solutions 

Slope  field  plots,  introduced  in  Chapter  1 2,  are  used  to  visualize  the  solutions 
to  a  differential  equation  of  the  form  dy/dx  =  f(x,y).  A  slope  field  plot  shows 
a  number  of  segments  tangential  to  the  solution  curves,  y  =  f(x).  The  slope  of 
the  segments  at  any  point  (x,y)  is  given  by  dy/dx  =  f(x,y),  evaluated  at  any 
point  (x,y),  represents  the  slope  of  the  tangent  line  at  point  (x,y). 

Example  1  -  Trace  the  solution  to  the  differential  equation  y'  =  f(x,y)  =  sin  x 
cos  y,  using  a  slope  field  plot.  To  solve  this  problem,  follow  the  instructions  in 
Chapter  1 2  for  slopefield  plots. 

If  you  could  reproduce  the  slope  field  plot  in  paper,  you  can  trace  by  hand 
lines  that  are  tangent  to  the  line  segments  shown  in  the  plot.  This  lines 
constitute  lines  of  y(x,y)  =  constant,  for  the  solution  of  y'  =  f(x,y).  Thus,  slope 
fields  are  useful  tools  for  visualizing  particularly  difficult  equations  to  solve. 

In  summary,  slope  fields  are  graphical  aids  to  sketch  the  curves  y  =  g(x)  that 
correspond  to  solutions  of  the  differential  equation  dy/dx  =  f(x,y). 
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The  CALC/DIFF  menu 

The  DIFFERENTIAL  EQNS..  sub-menu  within  the  CALC  )  menu 

provides  functions  for  the  solution  of  differential  equations.  The  menu  is  listed 
below  with  system  flag  1 1 7  set  to  CHOOSE  boxes: 


CHLC  HEnU 

l.DERIV.  a-.  IRTEG... 
Z. LIMITS  a  SERIES.. 

3.DIFFEREnTIflL  E4nS.. 

H.GRHRH.. 
5.DERVX 

e.inTVK 

1       1       1  IcflncLl 

OK 

DIFFEREnTIHL  ECRS  HEnU 

l.DESOLVE  1 

2.ILHF 
J.LflP 
H.LDEC 
E.CRLCULUS.. 

HELRI         1         1  ICHRCLI 

OK 

These  functions  are  briefly  described  next.  They  will  be  described  in  more 
detail  in  later  parts  of  this  Chapter. 

DESOLVE:  Differential  Equation  SOLVEr,  provides  a  solution  if  possible 
ILAP:  Inverse  LAPioce  transform,  L^[F(s)]  =  f(t) 
LAP:  LAPioce  transform,  L[f(t)]=F(s) 

LDEC:  solves  Linear  Differential  Equations  with  Constant  coefficients,  including 
systems  of  differential  equations  with  constant  coefficients 

Solution  to  linear  and  non-linear  equations 

An  equation  in  which  the  dependent  variable  and  all  its  pertinent  derivatives 
are  of  the  first  degree  is  referred  to  as  a  linear  differential  equation. 
Otherwise,  the  equation  is  said  to  be  non-linear.    Examples  of  linear 
differential  equations  are:  dWdt^  +  |3-(dx/dt)  +  a^  x  =  A  sin  cof  t,  and  dC/d\ 
+  u-(eC/5x)  =  D-(dK/dx^). 

An  equation  whose  right-hand  side  (not  involving  the  function  or  its  derivatives) 
is  equal  to  zero  is  called  a  homogeneous  equation.  Otherwise,  it  is  called 
non-homogeneous.  The  solution  to  the  homogeneous  equation  is  known  as  a 
general  solution.  A  particular  solution  is  one  that  satisfies  the  non- 
homogeneous  equation. 
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Function  LDEC 

The  calculator  provides  function  LDEC  (Linear  Differential  Equation  Command) 
to  find  tfie  general  solution  to  a  linear  ODE  of  any  order  with  constant 
coefficients,  whether  it  is  homogeneous  or  not.  This  function  requires  you  to 
provide  two  pieces  of  input: 

•  the  right-hand  side  of  the  ODE 

•  the  characteristic  equation  of  the  ODE 

Both  of  these  inputs  must  be  given  in  terms  of  the  default  independent  variable 
for  the  calculator's  CAS  (typically  'X').  The  output  from  the  function  is  the 
general  solution  of  the  ODE.   The  function  LDEC  is  available  through  in  the 
CALC/DIFF  menu.  The  examples  are  shown  in  the  RPN  mode,  however, 
translating  them  to  the  ALG  mode  is  straightforward. 

Example  1  -  To  solve  the  homogeneous  ODE:  d"^y/ dxM-(d'^y/ dx^)- 

1  1  (dy/dxl+aO  y  =  0,  enter:  i3  '  X--3-4-:rX-'-2- 1  l^X+BS  '  (maj 

LDEC.   The  solution  is: 

^■cCO-(.c^il*cC^^:>    5.K  10■cC0-(.7■cil-c^i^^:>    -(J.K)  15..:C0*Z..:C1-.:CZ 
 2H  *     *  HO  ■=         *  15  * 

where  cCO,  cCI,  and  cC2  are  constants  of  integration.  While  this  result 
seems  very  complicated,  it  can  be  simplified  if  we  take 

K1  =  (10*cC0-(7+cC1-cC2))/40,  K2  =  -(6*cC0-(cC1 +cC2))/24, 

and 

K3  =  (15*cC0+(2*cC1-cC2))/15. 

Then,  the  solution  is 

The  reason  why  the  result  provided  by  LDEC  shows  such  complicated 
combination  of  constants  is  because,  internally,  to  produce  the  solution,  LDEC 
utilizes  Laplace  transforms  (to  be  presented  later  in  this  chapter),  which 
transform  the  solution  of  an  ODE  into  an  algebraic  solution.  The  combination 
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of  constants  result  from  factoring  out  tfie  exponential  terms  after  tfie  Laplace 
transform  solution  is  obtained. 


Example  2  -  Using  thie  function  LDEC,  solve  tfie  non-homogeneous  ODE: 
d  VdxM-(d  Vdx')-1 1  -(dy/dxl+SO-y  =  xl 

Enter: 

'y,"'2.'  [enter)   '  !>:!'''3~4*X''2-"  1  i  aK+BQ  '  [enter]  LDEC 
Tfie  solution,  sfiown  partially  here  in  the  Equation  Writer,  is: 

?5D.cCD-<ia5.cCl+ia5.cCa+a>    S.K  270-cC0-(lSi-cCl-(.17-cCl-3y}       -<3'K>  H5D.K^*E3im+aHl  ( 
3000  lOSO  13500 

Replacing  the  combination  of  constants  accompanying  the  exponential  terms 
with  simpler  values,  the  expression  can  be  simplified  to  y  =  K^-e"'^"  +  Kj-e^"  + 
Kj-e^"-!-  (450-x2+330-x+241)/13500. 

We  recognize  the  first  three  terms  as  the  general  solution  of  the  homogeneous 
equation  (see  Example  1,  above).  If     represents  the  solution  to  the 
homogeneous  equation,  i.e.,  yi,  =  K,  e"'^''  +  Kj-e^"  +  Kj-e^".  You  can  prove 
that  the  remaining  terms  in  the  solution  shown  above,  i.e.,  yp  = 
(450-x2-i-330-x+241)/l  3500,  constitute  a  particular  solution  of  the  ODE. 


Note:  This  result  is  general  for  all  non-homogeneous  linear  ODEs,  i.e.,  given 
the  solution  of  the  homogeneous  equation,  yh(x),  the  solution  of  the 
corresponding  non-homogeneous  equation,  y{x),  can  be  written  as 

y(x)  =  yh(x)  +  yp(x), 

where  yp(x)  is  a  particular  solution  to  the  ODE.  

To  verify  that  yp  =  (450-x^+330-x+241  )/l  3500,  is  indeed  a  particular 
solution  of  the  ODE,  use  the  following: 

'  d  1  d  1  d  1 V  y.  >  -4*d  1  d  1 V  <  X  >  - 1 1  -sd  1 V  C  X  >  +38*V  OO  =  y/-^2 ' 

'  V     ==  1 45e*^■^•■■;;^^33i;;i*;:•^i■•24 1  >  / 1 3508 ' 

I--!  !r":i".-i"  !■-! 

oi_io.::i  I      i-  V  HL. 
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Allow  the  calculator  about  ten  seconds  to  produce  the  result:  = 
Example  3  -  Solving  a  system  of  linear  differential  equations  with  constant 
coefficients. 

Consider  the  system  of  linear  differential  equations: 

x/(t)  +  2x2'(t)  =  0, 
2x/(t)  +  X2'(t)  =  0. 

[1  2l 

in  algebraic  form,  this  is  written  as:  A-x'(t)  =  0,  where     ~  2    j  ' 

system  can  be  solved  by  using  function  LDEC  with  arguments  [0,0]  and  matrix 
A,  as  shown  in  the  following  screen  using  ALG  mode: 


^HD  KYZ  HEX  R=  'K' 


HLG 


LDEC[[0  0],[2  f]) 
cVl+cV2  _3'X^  cVl-cV2  _;: 

The  solution  is  given  as  a  vector  containing  the  functions  [xi(t),  X2(t)].  Pressing 

will  trigger  the  Matrix  Writer  allowing  the  user  to  see  the  two 
components  of  the  vector.  To  see  all  the  details  of  each  component,  press  the 
!lj][li]|  soft  menu  key.  Verify  that  the  components  are: 


( cV 1 +cV2  > /2*EXP ( 3*X  >  + 
<cVl-cV2V2*EXP<-X> 


EDIT   VEC  ■  HID-^  GO-^i  QtH- 


( cV  1 +cV2  V2*EXP  ( 3*X  > - 
<cVl-cV2V2*EXP<-X> 


EDIT   VEC  ■  +4IID   HID-^  GD-^i  QtH- 


Function  DESOLVE 

The  calculator  provides  function  DESOLVE  (Differential  Equation  SOLVEr)  to 
solve  certain  types  of  differential  equations.  The  function  requires  as  input  the 
differential  equation  and  the  unknown  function,  and  returns  the  solution  to  the 
equation  if  available.  You  can  also  provide  a  vector  containing  the 
differential  equation  and  the  initial  conditions,  instead  of  only  a  differential 
equation,  as  input  to  DESOLVE.  The  function  DESOLVE  is  available  in  the 
CALC/DIFF  menu.  Examples  of  DESOLVE  applications  are  shown  below 
using  RPN  mode. 

Example  1  -  Solve  the  first-order  ODE: 
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dy/dx  +  x^-y(x)  =  5. 

In  the  calculator  use: 

'  d  1  y  t  X  >  +x-"-2*y  C  x  =5  '         '  y  t  x  '  DEISOLVE 

The  solution  provided  is  {'y  = 

(INT(5*EXP(xt'^3/3),xt,x)+cC0)*l/EXP(x^3/3))' },  i.e., 

y(x)  =  exp(-x^  /  3)  •  [js  •  exp(x^  /3)-dx  +  cC^ ) 
The  variable  ODETYPE 

You  will  notice  in  the  soft-menu  key  labels  a  new  variable  called  lEEHEIEll 

(ODETYPE).  This  variable  is  produced  with  the  call  to  the  DESOL  function  and 
holds  a  string  showing  the  type  of  ODE  used  as  input  for  DESOLVE.  Press 
yiyiyjljljisj  to  obtain  the  string  "ist  order  linear". 

Example  2  -  Solve  the  second-order  ODE: 

d^y/dx^  -I-  X  (dy/dx)  =  exp(x). 

In  the  calculator  use: 

'd  i  d  i  y  '■.  X   "i"X*d  1  y  (.  X  y       Ei-'iP  f  X  f '  [cnter]  'y  (  :■:  5 '  Ientek]  DESGLVE 
The  result  is  an  expression  having  two  implicit  integrations,  namely, 


l: 

!j(x)=inT 

inr 

mi 

For  this  particular  equation,  however,  we  realize  that  the  left-hand  side  of  the 
equation  represents  d/dx(x  dy/dx),  thus,  the  ODE  is  now  written: 

d/ dx(x  dy/ dx  )  =  exp  x, 

and 

X  dy/ dx  =  exp  x  +  C. 
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Next,  we  can  write 

dy/dx  =  (C  +  exp  x)/x  =  C/x  +  eVx. 
In  the  calculator,  you  may  try  to  integrate: 

uiyvAJ  —        T  c'-.r  \  .K  y    y.K  {enter}  y^.K.  .■■  [enter]  l,t:oui_  v  c. 
The  result  is         { 'y(x)  =  INT({EXP{xt)+C)/xt,xt,x)+CO' },  i.e.. 

Performing  the  integration  by  hand,  we  can  only  get  it  as  far  as: 

■'  X 

because  the  integral  of  exp{x)/x  is  not  available  in  closed  form. 
Example  3  -  Solving  an  equation  with  initial  conditions.  Solve 

dV/dt'  +  5y  =  2  cos(t/2), 

with  initial  conditions 

y(0)  =  1 .2,  y'(0)  =  -0.5. 

In  the  calculator,  use: 

['dldly{t)-i-5*y(t)  =  2*COS(t/2)'  'y(O)  =  6/5'  'dly{0)  =  -1/2']  [m^ 

'y(t)'  \tmER] 

DESOLVE 

Notice  that  the  initial  conditions  were  changed  to  their  Exact  expressions,  'y(O) 
=  6/5',  rather  than  'y(0)=1.2',  and  'dly(O)  =  -1/2',  rather  than,  'dly(O)  =  - 
0.5'.  Changing  to  these  Exact  expressions  facilitates  the  solution. 


Note:  To  obtain  fractional  expressions  for  decimal  values  use  function 
(See  Chapter  5). 
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The  solution  is: 

95*  <  6^5 ) +-40 ) ^95  >  +- 1 ^ 
2*  t  TS*  1 9  V95*S  I H  a  *-J"5 


+^KIP|SKIP^  H)EL  I  DEL-f|DEL  L|  inS  ■ 


Press  dwTKMrito  simplify  the  result  to 

'y(t)  =  ■((19*V5*SIN(V5*t)-(148*COS(V5*t)+80*COS(t/2)))/190)'. 

Press  CWl  ElaiS  to  get  the  string  "Linear  w/  est  coeff"  for  the  ODE  type 
in  this  case. 

Laplace  Transforms 

The  Laplace  transform  of  a  function  f(t)  produces  a  function  F(s)  in  the  image 
domain  that  can  be  utilized  to  find  the  solution  of  a  linear  differential  equation 
involving  f(t)  through  algebraic  methods.   The  steps  involved  in  this 
application  are  three: 

1 .  Use  of  the  Laplace  transform  converts  the  linear  ODE  involving  f{t)  into  an 
algebraic  equation. 

2.  The  unknov/n  F(s)  is  solved  for  in  the  image  domain  through  algebraic 
manipulation. 

3.  An  inverse  Laplace  transform  is  used  to  convert  the  image  function  found 
in  step  2  into  the  solution  to  the  differential  equation  f(t). 

Definitions 

The  Laplace  transform  for  function  f(t)  is  the  function  F(s)  defined  as 

!•  CO 

L{f{t)}  =  Fis)=lf{t)-e-"dt. 

The  image  variable  s  can  be,  and  it  generally  is,  a  complex  number. 

Many  practical  applications  of  Laplace  transforms  involve  an  original  function 
f(t)  v/here  t  represents  time,  e.g.,  control  systems  in  electric  or  hydraulic 
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circuits.  In  most  cases  one  is  interested  in  the  system  response  after  time  t>0, 
thus,  the  definition  of  the  Laplace  transform,  given  above,  involves  an 
integration  for  values  of  t  larger  than  zero. 

The  inverse  Laplace  transform  maps  the  function  F(s)  onto  the  original  function 
f(t)  in  the  time  domain,  i.e.,  L  '^{F(s)}  =  f(t). 

The  convolution  integral  or  convolution  product  of  tv/o  functions  f(t)  and  g{t), 
where  g  is  shifted  in  time,  is  defined  as 

if*g)(t)  =  \jiu)-g(t-u)-du. 
Laplace  transform  and  inverses  in  the  calculator 

The  calculator  provides  the  functions  LAP  and  ILAP  to  calculate  the  Laplace 
transform  and  the  inverse  Laplace  transform,  respectively,  of  a  function  f(VX), 
v/here  VX  is  the  CAS  default  independent  variable,  v/hich  you  should  set  to  'X'. 
Thus,  the  calculator  returns  the  transform  or  inverse  transform  as  a  function  of 
X.  The  functions  LAP  and  ILAP  are  available  under  the  CALC/DIFF  menu.  The 
examples  are  v/orked  out  in  the  RPN  mode,  but  translating  them  to  ALG  mode 
is  straightforv^ard.  For  these  examples,  set  the  CAS  mode  to  Real  and  Exact. 


Example  1  -  You  can  get  the  definition  of  the  Laplace  transform  use  the 
follov/ing:  'ftX>'  (wra)  LAP  in  RPN  mode,  or  L..rir'f  fO^^  >  in  ALG  mode. 
The  calculator  returns  the  result  (RPN,  left;  ALG,  right): 


2: 
l: 


DE^OL  ILHP    LHP  LDEC 


LRPtftX)) 


DE^OL  ILHP    LHP  LDEC 


Compare  these  expressions  with  the  one  given  earlier  in  the  definition  of  the 
Laplace  transform,  i.e.. 


L{f(t)}  =  F(s)=[f(t)-e- 


'dt. 


and  you  will  notice  that  the  CAS  default  variable  X  in  the  equation  writer 
screen  replaces  the  variable  s  in  this  definition.    Therefore,  when  using  the 
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function  LAP  you  get  back  a  function  of  X,  wfiicfi  is  tfie  Laplace  transform  of 

f(X). 

Example  2  -  Determine  tfie  Laplace  transform  of  f(t)  =  e^*-sin(t).  Use: 
'EXP(2*X)*SIN(X)' («™]  LAP  The  calculator  returns  tfie  result:  l/(SQ(X-2)+l ). 
Press  (W)  to  obtain,  l/(XMX+5). 

Wfien  you  translate  tfiis  result  in  paper  you  would  write 

F(s)  =  L{e"-smt}  =  ^^  

s  -4-^  +  5 

Example  3  -  Determine  tfie  inverse  Laplace  transform  of  F(s)  =  sin(s).  Use: 

'SIN(X)'  [fNTH]  ILAP.     The  calculator  takes  a  few  seconds  to  return  the  result: 
'iLAP(SIN(X))',  meaning  that  there  is  no  closed-form  expression  f(t),  such  that  f(t) 
=  L-^{sin(s)}. 

Example  4  -  Determine  the  inverse  Laplace  transform  of  F(s)  =  1/s''.  Use: 
'l/X'^S'  [INTER}  ILAP  {jm}.  The  calculator  returns  the  result:  'X''2/2',  which  is 
interpreted  as  L  ^^{^/s^}  =  f/2. 

Example  5  -  Determine  the  Laplace  transform  of  the  function  f(t)  =  cos  (a-t+b). 
Use:  'COS(a*X+b)' I»7h)  LAP  .  The  calculator  returns  the  result: 

Press  P^T)  to  obtain  -(a  sin(b)  -  X  cos(b))/(X^-i-a^).  The  transform  is 
interpreted  as  follows:  L  {cos(a-t+b)}  =  (s-cos  b  -  a-sin  b)/(s^+a^). 

Laplace  transform  theorems 

To  help  you  determine  the  Laplace  transform  of  functions  you  can  use  a 
number  of  theorems,  some  of  which  are  listed  below.  A  few  examples  of  the 
theorem  applications  are  also  included. 

•     Differentiation  theorem  for  the  first  derivative.  Let  f^  be  the  initial  condition 
for  f(t),  i.e.,  f(0)  =  f„,  then 
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L{df/dt}  =  s-F(s)  -  f„. 


Example  1  -  The  velocity  of  a  moving  particle  v(t)  is  defined  as  v(t)  =  dr/dt, 
v/fiere  r  =  r(t)  is  the  position  of  the  particle.  Let  r^,  =  r{0),  and  R(s)  =L{r(t)},  then, 
the  transform  of  the  velocity  can  be  v/ritten  as  V{s)  =  L{v(t)}=L{dr/dt}=  s-R(s)-ro. 


•     Differentiation  theorem  for  the  second  derivative.  Let  f^  =  f(0),  and 
(df/dt)„  =  df/dt  I  ^0,  then  \.{6W}  =  s^.F(s)  -  s-f^  -  (df/dt)  „. 


Example  2  -  As  a  follow  up  to  Example  1 ,  the  acceleration  a(t)  is  defined  as 
a(t)  =  d^r/dt^.  If  the  initial  velocity  is  Vo  =  v(0)  =  dr/dt |,^o/  t^^en  the  Laplace 
transform  of  the  acceleration  can  be  v/ritten  as: 

A(s)  =  L{a(t)}  =  l{dW<i\'}=  s2-R(s)  -  s-r„  -  v„. 


•  Differentiation  theorem  for  the  n-th  derivative. 
Let  f  W„  =  dVdx^  1,^0-  and  f,  =  f(0),  then 

L{d"f/dt"}  =  s"-F(s)  -  s"-i-f„        sS"-\  -  f  „. 

•  Linearity  theorem.    L{af(t)+bg(t)}  =  a-L{f(t)}  +  b  L{g(t)}. 

•  Differentiation  theorem  for  the  image  function.  Let  F(s)  =  L{f(t)},  then 
d"F/ds"  =  L{(-t)"-f{t)}. 


Example  3  -  Let  f(t)  =  e""',  using  the  calculator  v/ith  'EXP(-a*X)'        LAP,  you 
get  'l/(X+a)',  or  F(s)  =  l/(s+a).   The  third  derivative  of  this  expression  can 
be  calculated  by  using: 

'X'l^CED  ^  'X'(^CED  a'X'(^CED  a  (MT) 

The  result  is 

'-6/(XM+4*a*X'^3+6*a''2*X'^2+4*a''3*X+a''4)',  or 
d^F/ds^  =  -6/(s^+4-a-s3+6-a2-s2+4-a3-s+a^). 
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Now,  use  '(-X)''3*EXP(-a*X)'        LAP  (W).  The  result  is  exactly  the  same. 


•  Integration  theorem.  Let  F(s)  =  L{f(t)},  then 

•  Convolution  theorem.  Let  F(s)  =  L{f(t)}  and  G(s)  =  L{g(t)},  then 

^lilmgH  -  ^)du\=  L{(/  *  g){t)}  = 

L{m}Mgit)}=m-G(s) 


Example  4  -  Using  the  convolution  theorem,  find  the  Laplace  transform  of 
(f*g)(t),  if  f(t)  =  sin(t),  and  g(t)  =  exp(t).  To  find  F(s)  =  L{f(t)},  and  G(s)  =  L{g(t)}, 
use:  'SIN(X)'  (S^  LAP  (]m).  Result,  '1/(X"2+1)',  i.e.,  F(s)  =  lAs^+l). 
Also,  'EXP(X)'        LAP.  Result,  '1/(X-1)',  i.e.,  G(s)  =  l/(s-l).  Thus,  L{(f*g){t)} 
=  F(s)-G(s)  =  l/(s2+l).l/(s-l)  =  l/((s-l)(s2+l))  =  l/{sV+s-l). 


•  Shift  theorem  for  a  shift  to  the  right.  Let  F(s)  =  L{f(t)},  then 

L{f(t-a)}=e-=.L{f(t)}  =  e-^F(s). 

•  Shift  theorem  for  a  shift  to  the  left.  Let  F(s)  =  L{f(t)},  and  a  >0,  then 

L{f{t  +  a)}  =  e-  ■  i^Fis)  -  £7(0  •  e  "  •  d?j. 

•  Similarity  theorem.  Let  F(s)  =  L{f(t)},  and  a>0,  then    L{f(a-t)}  = 
(l/a)-F{s/a). 

•  Damping  theorem.  Let  F(s)  =  L{f(t)},  then  L{e-'"-f(t)}  =  F(s+b). 

•  Division  theorem.  Let  F(s)  =  L{f(t)},  then 
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L{M}=J>)d 


lU. 


Laplace  transform  of  a  periodic  function  of  period  T: 


L{/(0}  = 


1 


\-e 


Limit  thieorem  for  tfie  initial  value:  Let  F(s)  =  L{f(t)},  tfien 


/o=lim/(0  =  lim[5-F(5)]. 

*->0  i->oo 


Limit  tfieorem  for  thie  final  value:  Let  F{s)  =  L{f{t)},  then 


/„=lim/(0  =  lim[5-F(5)]. 


Dirac's  delta  function  and  Heaviside's  step  function 

In  tfie  analysis  of  control  systems  it  is  customary  to  utilize  a  type  of  functions 
tfiat  represent  certain  pfiysical  occurrences  sucfi  as  tfie  sudden  activation  of  a 
switch)  (Heaviside's  step  function,  H(t))  or  a  sudden,  instantaneous,  peak  in  an 
input  to  the  system  (Dirac's  delta  function,  5(t)).  These  belong  to  a  class  of 
functions  known  as  generalized  or  symbolic  functions  [e.g.,  see  Friedman,  B., 
1 956,  Principles  and  Techniques  of  Applied  Mathematics,  Dover  Publications 
Inc.,  New  York  (1 990  reprint)  ]. 

The  formal  definition  of  Dirac's  delta  function,  5(x),  is  5(x)  =  0,  for  x  ^0,  and 


Also,  if  f(x)  is  a  continuous  function,  then      f{x)S{x  —  XQ)dx  =  /(Xq). 
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An  interpretation  for  the  integral  above,  paraphrased  from  Friedman  (1990), 
is  that  the  5-function  "picks  out"  the  value  of  the  function  f(x)  at  x  =  Xq.  Dirac's 
delta  function  is  typically  represented  by  an  upward  arrow  at  the  point  x  =  xO, 
indicating  that  the  function  has  a  non-zero  value  only  at  that  particular  value 

of  Xq. 


Heaviside's  step  function,  H(x),  is  defined  as 


fl,  x>0 
H{x)  =  \ 

0,  x<0 


Also,  for  a  continuous  function  f(x). 


/ {x)H{x  -  Xq  )dx  =     f  {x)dx. 


Dirac's  delta  function  and  Heaviside's  step  function  are  related  by  dH/dx 
5(x).  The  two  functions  are  illustrated  in  the  figure  below. 


You  can  prove  that  L{H(t)}  =  1/s, 

from  which  it  follows  that      L{U„-H(t)}  =  (J^s, 

where  Uq  is  a  constant.  Also,  L  ^{l/s}=H(t), 

and  L  ^{U,/s}=U„-H(t). 

Also,  using  the  shift  theorem  for  a  shift  to  the  right,  L{f(t-a)}=e  °'  L{f(t)}  = 

e-°^-F(s),  we  can  write  L{H(t-k)}=e-^^L{H(t)}  =  e-^=-(l/s)  =  (l/s)-e-^=. 
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Another  important  result,  known  as  the  second  shift  theorem  for  a  shift  to  the 
right,  is  that  L  '^e-^^  •F(s)}=f(t-a)  H(t-a),  with  F(s)  =  L{f(t)}. 

In  the  calculator  the  Heaviside  step  function  H(t)  is  simply  referred  to  as  '1 '. 
To  check  the  transform  in  the  calculator  use:  dD        LAP.  The  result  is  '1/X', 
i.e.,  L{1}  =  1/s.    Similarly,  'UO'        LAP  ,  produces  the  result  'UO/X',  i.e., 
L{Uo}  =  Uo/s. 

You  can  obtain  Diroc's  delta  function  in  the  calculator  by  using:  [  I  JtwraJ  ILAP 
The  result  is  'Delta  (X)'. 

This  result  is  simply  symbolic,  i.e.,  you  cannot  find  a  numerical  value  for,  say 

'Delta{5)'. 

This  result  con  be  defined  the  Laplace  transform  for  Dirac's  delta  function, 
because  from  L  "^{l  .0}=  8(t),  it  follows  that  L{8(t)}  =  1 .0 

Also,  using  the  shift  theorem  for  a  shift  to  the  right,  L{f(t-a)}=e  °'  L{f(t)}  = 
e^=-F(s),  we  can  write  L{8(t-k)}=e-^-L{5(t)}  =  e-^=-l  .0  =  e"^. 

Applications  of  Laplace  transform  in  the  solution  of  linear  ODEs 

At  the  beginning  of  the  section  on  Laplace  transforms  we  indicated  that  you 
could  use  these  transforms  to  convert  a  linear  ODE  in  the  time  domain  into  an 
algebraic  equation  in  the  image  domain.  The  resulting  equation  is  then 
solved  for  a  function  F(s)  through  algebraic  methods,  and  the  solution  to  the 
ODE  is  found  by  using  the  inverse  Laplace  transform  on  F(s). 

The  theorems  on  derivatives  of  a  function,  i.e., 

L{df/dt}  =  s-F(s)  -  f„, 

L{dW}  =  s2-F(s)-s.f„-(df/dt)„ 

and,  in  general, 

L{d"f/dt"}  =  s"-F(s)  -  s"-^-f„        s-f"-2'„  -  f  „ 
are  particularly  useful  in  transforming  an  ODE  into  an  algebraic  equation. 
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Example  1  -  To  solve  the  first  order  equation, 

dh/dt  +  l<-h{t)  =  a-e-', 

by  using  Laplace  transforms,  we  can  write: 

L{dfi/dt  +  k-fi(t)}  =  L{a-e-'}, 

L{dfi/dt}  +  k-L{fi(t)}  =  a-L{e-'}. 

Note:  'EXP(-X)'        LAP  ,  produces  '1/(X+1)',  i.e.,  L{e-'  }=1/(s+1).  

With  H(s)  =  L{h{t)},  and  L{dh/dt}  =  s  H(s)  -  h„,  where  h„  =  h{0),  the  transformed 
equation  is  s-H(s)-ho+k  H(s)  =  a/(s+l). 

Use  the  calculator  to  solve  for  H(s),  by  writing: 

'X*H-hO+k*H=a/(X+l)'^ 'H'  ISOL 

The  result  is         'H=((X+1  )*hO+a)/(X^2+(k+l )*X+k)'. 

To  find  the  solution  to  the  ODE,  h(t),  we  need  to  use  the  inverse  Laplace 
transform,  as  follows: 

OBJ^  L    J  [  4  Jlfv^iQ  isolates  right-hand  side  of  last  expression 

ILAP  Obtains  the  inverse  Laplace  transform 

a'e'^'^-mk-l)-hiQ-a)'e^ 
X  k  'X 

The  result  is  (k-l^e  .  Replacing  X  with  t  in  this  expression 

and  simplifying,  results  in  h(t)  =  a/(k-l  )  e*  -l-((k-l  )-ho-a)/{k-l  )-e^*. 

Check  what  the  solution  to  the  ODE  would  be  if  you  use  the  function  LDEC: 

'a*EXP(-X)'  (ENm}  'X+k'  {iNm}  LDEC  (mD 
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a'e'^'^+t[k-l)'cCS-a)'e^ 
The  result  is:  tk-D'e^'e*^'^        ,  i.e., 

h(t)  =  a/(k-l)-e-+((k-l)-cQa)/(k-l).e-^'. 

Thus,  cCO  in  the  results  from  LDEC  represents  the  initial  condition  h(0). 
Note:  When  using  the  function  LDEC  to  solve  a  linear  ODE  of  order  n  in  f(X), 
the  result  will  be  given  in  terms  of  n  constants  cCO,  cCI,  cC2,  cC(n-l), 
representing  the  initial  conditions  f(0),  f'(0),  f"(0),      f'""^'  (0).  

Example  2  -  Use  Laplace  transforms  to  solve  the  second-order  linear  equation, 

dVdt^+2y  =  sin  3t. 

Using  Laplace  transforms,  we  can  write: 

L{d  Vdt'+2y}  =  L{sin  3t}, 

l{6^y/df}  +  2-L{y(t)}  =  L{sin  3t}. 

Note:  'SIN(3*X)'        LAP  C™D  produces  '3/(X'^2+9)',  i.e., 

L{sin  3t}=3/(s2+9). 


With  Y(s)  =  L{y(t)},  and  L{dVdt'}  =  s2.Y(s)  -  s  y„  -  yi,  where  y„  =  h(0)  and  yi  = 
h'(0),  the  transformed  equation  is 

s2.Y(s)-s-y„-yi  +  2.Y(s)  =  3/(s2+9). 

Use  the  calculator  to  solve  for  Y{s),  by  writing: 

'X'^2*Y-X*yO-yl-(-2*Y=3/(X'^2+9)'(^  'Y'  ISOL 

The  result  is 

'Y=((X"2+9)*y1+(y0*X"3+9*y0*X+3))/(X"4+11*X"2+18)'. 
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To  find  the  solution  to  the  ODE,  y(t),  we  need  to  use  the  inverse  Laplace 
transform,  as  follows: 

OBJ^  L4J  I  4  J  Isolates  right-hand  side  of  last  expression 

ILAPd^  Obtains  the  inverse  Laplace  transform 

The  result  is 

(?■  JT'Lj  1  +3' J2')'S  I  m(  JI''X)-i- 1 4-LjS'C0S(  J2''X)-2'S  I  HQ'X) 

14 

i.e., 

y(t)  =  -(1/7)  sin  3x  +  y„  cos  V2x  +  (V2  (7yi-i-3)/14)  sin  V2x. 
Check  what  the  solution  to  the  ODE  would  be  if  you  use  the  function  LDEC: 
'SIN{3*X)'(^  'X^2+2'(^  IDECQm} 

The  result  is: 

(?■  J2''CC  1  ■^3■  J2']'S  I  h(  J2'■X]■^  1 4'cCS-C0S(  J2''X]-2'S  I HQ'^) 

14 

i.e.,  the  same  as  before  with  cCO  =  yO  and  cCl  =  yl . 


Note:  Using  the  two  examples  shown  here,  we  can  confirm  what  we 

indicated  earlier,  i.e.,  that  function  ILAP  uses  Laplace  transforms  and  inverse 
transforms  to  solve  linear  ODEs  given  the  right-hand  side  of  the  equation  and 
the  characteristic  equation  of  the  corresponding  homogeneous  ODE. 


Example  3  -  Consider  the  equation 

d^y/dt^+y  =  5(t-3), 
where  8(t)  is  Dirac's  delta  function. 

Using  Laplace  transforms,  we  can  write: 

L{dV/dt^-Fy}  =  L{5{t-3)}, 
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L{d  Vdt'}  +  L{y(t)}  =  L{5(t-3)}. 

With  'Delta  (x-3) '  (£N7H]  LAP  ,  the  Calculator  produces  EXP(-3*X),  i.e.,  L{8(t-3)} 
=  e-3^  With  Y(s)  =  L{y(t)},  and  L{dVdt'}  =  s2-Y(s)  ■  s-y„  -  y„  where  y,  =  h(0) 
and  yi  =  h'(0),  the  transformed  equation  is  s^-Y(s)  -  s-yo  -  yi  +  Y(s)  =  e~^\  Use 
the  calculator  to  solve  for  Y(s),  by  writing: 

'X'^2*Y-X*yO-yl+Y=EXP(-3*X)'(^  'Y'  ISOL 
The  result  is       'Y=(X*yO+(yl  +EXP(-(3*X))))/(X"2+1 )'. 

To  find  the  solution  to  the  ODE,  y(t),  we  need  to  use  the  inverse  Laplace 
transform,  as  follows: 

OBJ^  I  4  J  I  4  J  Isolates  right-hand  side  of  last  expression 

ILAP      [Mi}  Obtains  the  inverse  Laplace  transform 

The  result  is  'yi  *SIN(X)+yO*COS(X)+SIN(X-3)*Heaviside(X-3)'. 

Notes: 

[1].  An  alternative  way  to  obtain  the  inverse  Laplace  transform  of  the 
expression  '(X*yO+(yl +EXP(-(3*X))))/(X'^2+1 )'  is  by  separating  the 
expression  into  partial  fractions,  i.e., 

'yO*X/(X'^2+l)  +  yl/(X'^2+l)  +  EXP(-3*X)/(X'^2+1 )', 

and  use  the  linearity  theorem  of  the  inverse  Laplace  transform 

L  -^{a-FCsl+b-Gls)}  =  a-L  '{Fis)}  +  b-L  '{Gis)}, 

to  write, 

L  ■i{y„.s/(s^+l )+yy(s2+l ))  +  e-'V(s'+^)) }  = 
y„.L-Ms/(s^+l)}+  yrL-Ml/(s'+l)}+  LMe-V{s^+l))}, 
Then,  we  use  the  calculator  to  obtain  the  following: 
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'X/{X^2+]y  (ENm}  ILAP  Result,  'COS(X)',  i.e.,  L -'{s/(s^+^)}=  cos  t. 

'1/(X"2+1)'(^  ILAP  Result, 'SIN(X)',  i.e.,  L  -^{l/(s2+l)}=  sin  t. 

'EXP(-3*X)/(X'^2+1)'  {ENm)  ILAP    Result,  SIN(X-3)*Heaviside(X-3)'. 

[2].  The  very  last  result,  i.e.,  the  inverse  Laplace  transform  of  the  expression 
'(EXP(-3*X)/(X''2+1))',  can  also  be  calculated  by  using  the  second  shifting 
theorem  for  a  shift  to  the  right 

\.  '{e-°'  •F(s)}=f{t-a)-H(t-a), 

if  we  con  find  an  inverse  Laplace  transform  for  l/(s^+1).  With  the  calculator, 
try  '1/(X'^2+1)'  QNm)  ILAP.  The  result  is  'SIN{X)'.  Thus,  L  -^ie-Vls'+l ))}  = 
sin(t-3)-H(t-3), 


Check  v/hat  the  solution  to  the  ODE  v/ould  be  if  you  use  the  function  LDEC: 

'Delta(X-3)' 'X''2+^' [enter)  LDEC  dwT) 

The  result  is: 

'SIN(X-3)*Heaviside(X-3)  +  cCl  *SIN(X)  +  cC0*COS(X)+'. 

Please  notice  that  the  variable  X  in  this  expression  actually  represents  the 
variable  t  in  the  original  ODE.  Thus,  the  translation  of  the  solution  in  paper 
may  be  written  as: 

y(t)  =  Co  •  cos  ^  +  Ci  •  sin  t  +sm(t  -  3)  •  H(t  -  3) 

When  comparing  this  result  with  the  previous  result  for  y(t),  we  conclude  that 
cC„  =  y„,  cC,  =  y,. 
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Defining  and  using  Heaviside's  step  function  in  the  calculator 

The  previous  example  provided  some  experience  v/ith  the  use  of  Diroc's  delta 
function  as  input  to  a  system  (i.e.,  in  the  right-hand  side  of  the  ODE  describing 
the  system).  In  this  example,  v/e  wont  to  use  Heaviside's  step  function,  H(t). 
In  the  calculator  we  can  define  this  function  as: 

'H(X)  =  IFTE(X>0,  1,  0)'  (e^{^del_ 

This  definition  will  create  the  variable  ISUSI  in  the  calculator's  soft  menu  key. 

Example  1  -  To  see  a  plot  of  H(t-2),  for  example,  use  a  FUNCTION  type  of 
plot  (see  Chapter  1 2): 

•  Press  CTJiMo  ,  simultaneously  in  RPN  mode,  to  access  to  the  PLOT  SETUP 
window. 

>  Change  type  to  function,  if  needed 

>  Change  EG  to  'H(X-2)'. 

>  Make  sure  that  indep  is  set  to  'X'. 

>  Press  (nxt)  ilSfflito  return  to  normal  calculator  display. 

•  Press  UnJ  J?*L ,  simultaneously,  to  access  the  PLOT  window. 

>  Change  the  H-VIEW  range  to  0  to  20,  and  the  V-VIEW  range  to  -2  to  2. 

>  Press         S333j  to  plot  the  function  . 

Use  of  the  function  H(X)  with  LDEC,  LAP,  or  ILAP,  is  not  allowed  in  the 
calculator.  You  have  to  use  the  main  results  provided  earlier  when  dealing 
with  the  Heaviside  step  function,  i.e.,    L{H(t)}  =  1/s,  L  ■'{l/s}=H(t), 
L{H(t-k)}=e-^=-L{H(t)}  =  e-^=-(l/s)  =  -(l/sj-e-^^  and  L  -^fe^^  •F(s)}=f(t-a)-H(t-a). 

Example  2  -  The  function         when  multiplied  to  a  function  f(t),  i.e.,  H(t-tjf(t), 
has  the  effect  of  switching  on  the  function  f(t)  at  t  =  t^.  For  example,  the 
solution  obtained  in  Example  3,  above,  was  y(t)  =  y^  cos  t  +  y,  sin  t  +  sin(t- 
3)-H(t-3).  Suppose  we  use  the  initial  conditions  yo  =  0.5,  and  yi  =  -0.25. 
Let's  plot  this  function  to  see  what  it  looks  like: 

•  Press  UjJ^SHH.  ,  simultaneously  if  in  RPN  mode,  to  access  to  the  PLOT 
SETUP  window. 
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>  change  type  to  function,  if  needed 

>  Change  EQ  to  '0.5*COS(X)-0.25*SIN(X)+SIN(X-3)*H(X-3)'. 

>  Make  sure  that  indep  is  set  to  'X'. 

>  Press  ll-ilj!lj!l§l-il  OMlLlI  to  plot  the  function. 

>  Press  IliEiiEil  (W)  EEHa  to  see  the  plot. 

The  resulting  graph  will  look  like  this: 


Notice  that  the  signal  starts  with  a  relatively  small  amplitude,  but  suddenly,  at 
t=3,  it  switches  to  an  oscillatory  signal  with  a  larger  amplitude.  The 
difference  between  the  behavior  of  the  signal  before  and  after  t  =  3  is  the 
"switching  on"  of  the  particular  solution  yp(t)  =  sin(t-3)  H(t-3).  The  behavior  of 
the  signal  before  t  =  3  represents  the  contribution  of  the  homogeneous 
solution,  yh(t)  =  y^  cos  t  +  y,  sin  t. 

The  solution  of  an  equation  with  a  driving  signal  given  by  a  Heaviside  step 
function  is  shown  below. 

Example  3  -  Determine  the  solution  to  the  equation,  d^y/dt^+y  =  H(t-3), 
where  H(t)  is  Heaviside's  step  function.    Using  Laplace  transforms,  we  can 
write:  L{d  Vdt'+y}  =  L{H(t-3)},  [{d^y/dt^}  +  L{y(t)}  =  L{H(t-3)}.  The  last  term  in 
this  expression  is:  L{H(t-3)}  =  (^/s)■e-^\  With  Y(s)  =  L{y(t)},  and  L{dVdt'}  = 
s^  Y(s)  -  s-yo  -  yi,  where  y^  =  h(0)  and  yi  =  h'(0),  the  transformed  equation  is 
s^  Y(s)  -  s-y^  -  yi  +  Y(s)  =  (l/s)  e""^'.  Change  CAS  mode  to  Exact,  if  necessary. 
Use  the  calculator  to  solve  for  Y(s),  by  writing: 

'X'^2*Y-X*yO-y1+Y=(l/X)*EXP(-3*X)'(^  'Y'  ISOL 

The  result  is  'Y=(X^2*yO+X*yl  +EXP(-3*X))/(X"3+X)'. 

To  find  the  solution  to  the  ODE,  y(t),  we  need  to  use  the  inverse  Laplace 
transform,  as  follows: 
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OBJ^  CiJ 
ILAP 


Isolates  right-hand  side  of  last  expression 
Obtains  the  inverse  Laplace  transform 


The  result  is      'y  1  *SIN(X-1  )+yO*COS(X-l  HCOS(X-3)-l  )*Heaviside(X-3)'. 
Thus,  we  write  as  the  solution:   y(t)  =  y^  cos  t  +  yi  sin  t  +  H(t-3)-(l  +sin(t-3)). 
Check  what  the  solution  to  the  ODE  would  be  if  you  use  the  function  LDEC: 
'H(X-3)'       [ENTER]  'X^2+l'  LDEC 

The  result  is: 

f*Vi 


■mt  +cCl.Sin(K>+cCD.COSCl{> 


Please  notice  that  the  variable  X  in  this  expression  actually  represents  the 
variable  t  in  the  original  ODE,  and  that  the  variable  ttt  in  this  expression  is  a 
dummy  variable.  Thus,  the  translation  of  the  solution  in  paper  may  be  written 
as: 

y(t)  =  Co-cost  +  Ci  -sin^  +  sin^-  j^H(u-3)-e  "  -du. 

Example  4  -  Plot  the  solution  to  Example  3  using  the  same  values  of  yo  and  yi 
used  in  the  plot  of  Example  1 ,  above.  We  now  plot  the  function 

y(t)  =  0.5  cos  t  -0.25  sin  t  +  (1 +sin(t-3))-H(t-3). 

In  the  range  0  <  t  <  20,  and  changing  the  vertical  range  to  (-1,3),  the  graph 
should  look  like  this: 
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Again,  there  is  a  new  component  to  the  motion  switched  at  t=3,  namely,  the 
particular  solution  yp(t)  =  [1 +sin(t-3)]-H(t-3),  which  changes  the  nature  of  the 
solution  for  t>3. 

The  Heaviside  step  function  can  be  combined  with  a  constant  function  and 
with  linear  functions  to  generate  square,  triangular,  and  saw  tooth  finite  pulses, 
as  follows: 

•  Square  pulse  of  size  \J„  in  the  interval  a  <  t  <  b: 

f(t)  =  Uo[H(t-a)-H(t-b)]. 

•  Triangular  pulse  with  a  maximum  value  Uo,  increasing  from  a  <  t  <  b, 
decreasing  from  b  <  t  <  c: 

f(t)  =  U,.  ((t-a)/(b-a).[H(t-a)-H(t-b)]+(l-(t-b)/(b-c))[H(t-b)-H(t-c)]). 

•  Saw  tooth  pulse  increasing  to  a  maximum  value  Uo  for  a  <  t  <  b, 
dropping  suddenly  down  to  zero  at  t  =  b: 

f{t)  =  U„.  (t-a)/(b-a).[H(t-a)-H(t-b)]. 

•  Saw  tooth  pulse  increasing  suddenly  to  a  maximum  of  Uo  at  t  =  a,  then 
decreasing  linearly  to  zero  for  a  <  t  <  b: 

f(t)  =  U„.[l-(t-a)/(b-l)].[H(t-a)-H(t-b)]. 

Examples  of  the  plots  generated  by  these  functions,  for  Uo  =  1 ,  a  =  2,  b  =  3, 
c  =  4,  horizontal  range  =  (0,5),  and  vertical  range  =  (-1,  1.5),  are  shown  in 
the  figures  below: 


Iv 

.1. 

Iv 

e. 

5. 

J. 

r  J. 

Iv 

Iv 

X 

e. 

s. 

J. 

0. 

r  J. 

5. 

Page  1 6-26 


Fourier  series 

Fourier  series  are  series  involving  sine  and  cosine  functions  typically  used  to 
expand  periodic  functions.  A  function  f(x)  is  said  to  be  periodic,  of  period  T, 
if  f(x+T)  =  f(t).  For  example,  because  sin(x+2ji)  =  sin  x,  and  cos(x+27c)  =  cos 
X,  tfie  functions  sin  and  cos  are  27:-periodic  functions.  If  two  functions  f(x)  and 
g(x)  are  periodic  of  period  T,  then  tfieir  linear  combination  h(x)  =  a-f(x)  + 
b  g(x),  is  also  periodic  of  period  T.  A  T-periodic  function  f(t)  can  be 
expanded  into  a  series  of  sine  and  cosine  functions  known  as  a  Fourier  series 
given  by 

^,  ^  -^f  Inn     ,      .  2n7t  ^ 

fit)  =  «o  +  Z      •  cos— +  b„  ■  sm— 

«=iv  ^  J 

wfiere  tfie  coefficients  a^  and  b^  are  given  by 

1  fTii                     2  rTi2  2nn 
ar,=—\      f{t)-dt,    a„=—\      fit) -cos  r 

"       f  J-r/2  "       f  J-T/2  f 


dt. 


b  =       /(0-sin  t-dt. 


Thie  following  exercises  are  in  ALG  mode,  witfi  CAS  mode  set  to  Exact. 
(When  you  produce  a  graph,  the  CAS  mode  will  be  reset  to  Approx.  Make 
sure  to  set  it  back  to  Exact  after  producing  the  graph.)  Suppose,  for  example, 
that  the  function  f(t)  =  t^+t  is  periodic  with  period  T  =  2.  To  determine  the 
coefficients  Oq,  a^,  and  b,  for  the  corresponding  Fourier  series,  we  proceed  as 
follows:  First,  define  function  f(t)  =  t^+t  : 


Next,  we'll  use  the  Equation  Writer  to  calculate  the  coefficients: 
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Thus,  the  first  three  terms  of  the  function  ore: 

f(t)  «  1/3  -  (W)-cos  {7r-t)+(2/7i)-sin  (n-\). 


A  graphical  comparison  of  the  original  function  with  the  Fourier  expansion 
using  these  three  terms  shows  that  the  fitting  is  acceptable  for  t  <  1 ,  or 
thereabouts.  But,  then,  again,  we  stipulated  that  T/2  =  1 .  Therefore,  the 
fitting  is  valid  only  between  -1  <  t  <  1 . 


3. 

V  / 

i.-'-ffj 

r  '  '  '      '  VJ^  a!5 

Function  FOURIER 

An  alternative  way  to  define  a  Fourier  series  is  by  using  complex  numbers  as 
follows: 

where 
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^«  =7;;  J„/(0-exp(  t)-dt,    «  =  -Qo,...-2-l,0,l,2,-°o. 

7   JO  7 

Function  FOURIER  provides  the  coefficient  c^  of  the  complex-form  of  the 
Fourier  series  given  the  function  f(t)  and  the  value  of  n.  The  function  FOURIER 
requires  you  to  store  the  value  of  the  period  (T)  of  a  T-periodic  function  into 
the  CAS  variable  PERIOD  before  calling  the  function.  The  function  FOURIER  is 
available  in  the  DERIV  sub-menu  within  the  CALC  menu  ((.  *i  )calc  ). 

Fourier  series  for  a  quadratic  function 

Determine  the  coefficients  Cq,  Ci,  and  C2  for  the  function  f(t)  =  t^-i-t,  with  period 
T  =  2.  (Note:  Because  the  integral  used  by  function  FOURIER  is  calculated  in 
the  interval  [0,T],  while  the  one  defined  earlier  was  calculated  in  the  interval 
[-T/2,T/2],  we  need  to  shift  the  function  in  the  t-axis,  by  subtracting  T/2  from  t, 
i.e.,  we  will  use  g(t)  =  f(t-l )  =  (t-1  ).) 

Using  the  calculator  in  ALG  mode,  first  we  define  functions  f(t)  and  g(t): 


:DEFIHE(f(t)=t  -Ht  ) 

HOVRL 
:DEFIHE('9(t)=f(t-15') 

Next,  we  move  to  the  CASDIR  sub-directory  under  HOME  to  change  the  value 
of  variable  PERIOD,  e.g.,  (jT]  (hold)  ™L  (w7h}[W]  {cNm}[JJ  iwi 

I J  JUlJiJil  [ENm)  


HOVRL 

:H0ME 

HOVRL 

iCflSDIR 

HOVRL 

:2^PERI0D 

2 

PRIHIICH^iniHODULIREHLHIPERIOl 

Return  to  the  sub-directory  where  you  defined  functions  f  and  g,  and  calculate 
the  coefficients  (Accept  change  to  Complex  mode  when  requested): 
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:FOURIERt9(X),0) 

2 
3 
2 

:F0URIERt9(X),l) 

3 

2'i'iT+4 

2 

2 

:F0URIERt9(X),2) 

TT 

i'TT+1 

2 

TT 

2 

COLLECTtflHSd)) 


TT 

2 

:C0LLECTtflHS(l)5 

i'TT+2 

2 

TT 

TT 

2 

:C0LLECTtRHS(l)5 

i'TT+1 

2.TT^ 

Thus,  Cq  =  1/3,  Ci  =  {7r-i+2)/7T:^,  C2  =  (n-i+l  )/(27i^). 

The  Fourier  series  with  three  elements  will  be  written  as 

g(t)  *  Re[{l/3)  +  (7r-i+2)A2.exp(i-7r-t)+  (Ti-i+l  )/{27i2)-exp(2-i-7r-t)]. 
A  plot  of  the  shifted  function  g(t)  and  the  Fourier  series  fitting  follows: 


-a. 

-1. 

 2. 

The  fitting  is  somewhat  acceptable  for  0<t<2,  although  not  as  good  as  in  the 
previous  example. 
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A  general  expression  for  c„ 

The  function  FOURIER  can  provide  a  general  expression  for  thie  coefficient  c^ 
of  tfie  complex  Fourier  series  expansion.  For  example,  using  tfie  same 
function  g(t)  as  before,  the  general  term  c„  is  given  by  (figures  show  normal 
font  and  small  font  displays): 


2-Tr 

:FOURIERtQ(X),n) 

(rTTT+2.  i  >e   ^  ''^■^+2.  i  ti^-tt^h 

(n.n+a.iJ.«^'^"*'^+a.i.n^.n^+3.n.a-a.i 

3  3  2'iTi'ir  t- 
n  'TT  'e 

n  in 

 2  

a 

The  general  expression  turns  out  to  be,  after  simplifying  the  previous  result, 

(nn:  +  2i)  ■  e'""  +  2i^n^^^  +  3n;r  -  2i 

c  =  ^  

In  TV  -e 

We  can  simplify  this  expression  even  further  by  using  Euler's  formula  for 
complex  numbers,  namely,  e^'"''  =  cos(2n7t)  +  i-sin(2n7r)  =  1  +  i-0  =  1,  since 
cos(2n7r)  =  1,  and  sin(2n7t)  =  0,  for  n  integer. 

Using  the  calculator  you  can  simplify  the  expression  in  the  equation  v/riter 
([  r»  J  fonf )  by  replacing  e^'""  =  1.  The  figure  shows  the  expression  after 
simplification: 


EDIT  I  CUR£  I  EIG  ■!  EVHL  |FHCTO|  SIW 


The  result  is  c„  =  (i-n-7i+2)/(n^-7T:^). 

Putting  together  the  complex  Fourier  series 

Having  determined  the  general  expression  for  c^,  we  can  put  together  a  finite 
complex  Fourier  series  by  using  the  summation  function  (E)  in  the  calculator  as 
follows: 
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•     First,  define  a  function  c(n)  representing  tfie  general  term     in  tfie  complex 
Fourier  series. 


: DEFINE 

n  'TT 

 tiOVRL 

•  Next,  define  the  finite  complex  Fourier  series,  F(X,k),  wfiere  X  is  tfie 
independent  variable  and  k  determines  the  number  of  terms  to  be  used. 
Ideally  we  would  like  to  write  this  finite  complex  Fourier  series  as 

F(X,A:)=t^(«)-exp(^^^-X) 

n=-k  ^ 

However,  because  the  function  c(n)  is  not  defined  for  n  =  0,  we  will  be 
better  advised  to  re-write  the  expression  as 

F(X,k,cO)  =  cO  + 

,  ,        ,2-/-;7-R  l-i-TT-n 
2J.c{n)  ■  exp(  X)  +  c{-n)  ■  exp(  X)], 

n=l  i  ^ 

Or,  in  the  calculator  entry  line  as: 

DEFINE('F(X,k,cO)  =  cO+Z(n=l  ,k,c(n)*EXP(2*i*7i*n*X/T)+ 
c(-n)*EXP(-(2*i*7i*n*X/T))'), 

where  T  is  the  period,  T  =  2.  The  following  screen  shots  show  the  definition  of 
function  F  and  the  storing  of  T  =  2: 
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DEFIHEt 'F^X,k,c0>=c0+ 
ir*n*X^PER  I OD  >  +c  t  -n  >  * 
EXP  i  -2*  i  *Tr*n*X/PER  I OD 


t^KIP  SKIP-H  H)EL   DEL-f  DEL  L  inS  ■■+^KIP  SKIP-H  H)EL   DEL-f  DEL  L  IDS  ■ 


The  function  SiS  can  be  used  to  generate  the  expression  for  the  complex 
Fourier  series  for  a  finite  value  of  k.  For  example,  for  k  =  2,  Cq  =  1/3, and 
using  t  as  the  independent  variable,  v/e  can  evaluate  F(t,2, 1/3)  to  get: 


tS.SS,6.; 


2.0G^ 


This  result  shows  only  the  first  term  (cO)  and  part  of  the  first  exponential  term 
in  the  series.  The  decimal  display  format  v/as  changed  to  Fix  with  2  decimals 
to  be  able  to  show  some  of  the  coefficients  in  the  expansion  and  in  the 
exponent.  As  expected,  the  coefficients  are  complex  numbers. 


The  function  F,  thus  defined,  is  fine  for  obtaining  values  of  the  finite  Fourier 
series.  For  example,  a  single  value  of  the  series,  e.g.,  F(0.5,2, 1/3),  can  be 
obtained  by  using  (CAS  modes  set  to  Exact,  step-by-step,  and  Complex): 


^.5.2^] 


^■K-. 737940956009,0.) 

-^HUMtRHSd.)) 

[-■404607622676,0.) 


Accept  change  to  Approx  mode  if  requested.   The  result  is  the  value 
-0.40467....  The  actual  value  of  the  function  g(0.5)  is  g(0.5)  =  -0.25.  The 
following  calculations  show  how  well  the  Fourier  series  approximates  this 
value  as  the  number  of  components  in  the  series,  given  by  k,  increases: 

F  (0.5,  1,1/3)  =  (-0.303286439037,0.) 

F  (0.5,  2,  1/3)  =  (-0.404607622676,0.) 

F  (0.5,  3,  1/3)  =  (-0.192401031886,0.) 
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F  (0.5,  4,  1/3)  =  (-0.167070735979,0.) 
F  (0.5,  5,  1/3)  =  (-0.294394690453,0.) 
F  (0.5,  6,  1/3)  =  (-0.305652599743,0.) 


To  compare  the  results  from  the  series  with  those  of  the  original  function,  load 
these  functions  into  the  PLOT  -  FUNCTION  input  form  (CT]^ , 
simultaneously  if  using  RPN  mode): 


EDIT  I  HDD  I  DEL  |CHOO£|ERA£E|  DRHH 


Change  the  limits  of  the  Plot  Window  ([^ML  )  as  follows: 


PLOT  HIDDDH  -  FUnCTIDD^^ 
H-Vi<H:-.5  a. 

v-viiH--i.  a. 


AUTO  ERA^E  DRAH 


Press  the  soft-menu  keys  BJEEeHI  BjIEuIII  to  produce  the  plot: 


-1. 

Notice  that  the  series,  with  5  terms,  "hugs"  the  graph  of  the  function  very 
closely  in  the  interval  0  to  2  (i.e.,  through  the  period  T  =  2).  You  can  also 
notice  a  periodicity  in  the  graph  of  the  series.  This  periodicity  is  easy  to 
visualize  by  expanding  the  horizontal  range  of  the  plot  to  (-0.5,4): 
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Fourier  series  for  o  triangular  wave 

Consider  the  function 


g(x)  = 


\  X,    if 0<x<l 
\2-x,  if\<x<2 


which  we  assume  to  be  periodic  with  period  T  =  2.  This  function  can  be 
defined  in  the  calculator,  in  ALG  mode,  by  the  expression 


DEFINE('g(X)  =  IFTE(X<1  ,X,2-X)') 

If  you  started  this  example  after  finishing  example  1  you  already  have  a  value 
of  2  stored  in  CAS  variable  PERIOD.  If  you  are  not  sure,  check  the  value  of 
this  variable,  and  store  a  2  in  it  if  needed.   The  coefficient  Cq  for  the  Fourier 
series  is  calculated  as  follows: 


:FOURIERt9(X),0) 

■  IFTE(Xt<l.,Xt,-(Xt-2^ 

■  IFTE(Xt<l.,Xt,-tXt-2, 

,  0.  ' 

2 

:-*HUM(RHS(l.)) 

.5 

2. 

The  calculator  will  request  a  change  to  Approx  mode  because  of  the 
integration  of  the  function  IFTE()  included  in  the  integrand.  Accepting,  the 
change  to  Approx  produces  Cq  =  0.5.  If  we  now  want  to  obtain  a  generic 
expression  for  the  coefficient  c^  use: 
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i-uuKitKigi^^J^nj 

IFTEtXt<l..Xt.-tXt- 


The  calculator  returns  on  integral  that  cannot  be  evaluated  numerically 
because  it  depends  on  the  parameter  n.    The  coefficient  can  still  be 
calculated  by  typing  its  definition  in  the  calculator,  i.e., 


1  fi 
-•  \XEXP 
7  Jo 


^   i-2-  n  ■  7T  ■  X 


■dX  + 


^-■\[{2-X)-EXP 


i  -  l-n-  71  ■  X 


dX 


where  T  =  2  is  the  period.  The  value  of  T  can  be  stored  using: 


:2^T 

Z 

Typing  the  first  integral  above  in  the  Equation  Writer,  selecting  the  entire 
expression,  and  using  ,  will  produce  the  following: 


iTi'ir  . 

e  -ITl'TT-l 


„  2  2  iTi'ir 
2ti  'TT 


EDIT   CUR£   eiG  ■  EVHL  FHCTO  SIW 


Recall  the  e'"''  =  cos(n7r)  +  i-sin(n7t)  =  (-1 )"  .  Performing  this  substitution  in  the 
result  above  we  have: 
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C-l)  -iTTTT-l 


EDIT   CURS   EIG  ■  EVflL  FflCTO  SIMP 


Press  [ENTERjifNTER)  fo  copy  this  result  to  the  screen.  Then,  reactivate  the  Equation 


Writer  to  calculate  the  second  integra 


C2-X>e 


1 


dX4 


defining  the  coefficient  c^,  namely, 


EDIT   CURS   EIC  ■  EVHL  FHCTD  SIHR  H  EDIT   CURS   DIG  ■  EVHL  FHCTD  SIHR 


Once  again,  replacing  e'""  =  (-1)",  and  using  e^'""  =  1,  we  get: 


Press  {EmEK}{ENTER}  fo  copy  this  second  result  to  the  screen.  Now,  add  ANS(1 ) 
and  ANS(2)  to  get  the  full  expression  for 


m  n  


RHS(1)+RHS(2) 

iTl'TT 


+  iTl'Tr-l^[-[iTl'TT)+l 


^22  iTi-TT  ^22 
2ti  'TT  ■&  2ti  -tt 


RRHR  SOLVR  STHTS  DDES  HDS 


Pressing  will  place  this  result  in  the  Equation  Writer,  where  we  can 
simplify  (Elllil)  it  to  read: 


iTl'TT 

-1 

e  + 

2  2  i 

ri'TT 

n  'TT  'e 

EDIT   CURS   RIG  ■  EVflL  FflCTD  SIMP 
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Once  again,  replacing  e'""  =  (-1)",  results  in 


This  result  is  used  to  define  the  function  c{n)  as  follows: 

DEFINE('c(n)  =  -  (((-1  j'^n-l  )/(n'^2*7r''2*(-l  )^n)') 


I.e. 


I  DEFINE 


c(n)=- 


[-1)^-1 

n  'TT  ■(-!) 
HOVRU 


Next,  we  define  function  F(X,l<,cO)  to  calculate  the  Fourier  series  (if  you 
completed  example  1,  you  already  have  this  function  stored): 

DEFINE('F(X,k,cO)  =  cO+Z(n=l  ,k,c(n)*EXP(2*i*7i*n*X/T)+ 
c(-n)*EXP(-(2*i*7i*n*X/T))'), 


To  compare  the  original  function  and  the  Fourier  series  we  can  produce  the 
simultaneous  plot  of  both  functions.  The  details  are  similar  to  those  of 
example  1 ,  except  that  here  we  use  a  horizontal  range  of  0  to  2  and  a 
vertical  range  from  0  to  1,  and  adjust  the  equations  to  plot  as  shown  here: 


Vl(X)=c 

PLOT  -  FuncTion^^^^ 

(X)   

t 

MOVE+|MOVE+|CLEflR 

1  1 

CflnCLI  OK 
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The  resulting  graph  is  shown  below  for  k  =  5  (the  number  of  elements  in  the 
series  is  2k+l,  i.e.,  1  1,  in  this  cose): 


From  the  plot  it  is  very  difficult  to  distinguish  the  original  function  from  the 
Fourier  series  approximation.  Using  k  =  2,  or  5  terms  in  the  series,  shows  not 
so  good  a  fitting: 


mmm 

PLOT  -  FuncTion^^^ 

(X) 

EDITI  HDD 

DEL  ICHOO^IERA^EI  DRHH 

V 


+ 


The  Fourier  series  can  be  used  to  generate  a  periodic  triangular  wave  (or  saw 
tooth  wave)  by  changing  the  horizontal  axis  range,  for  example,  from  -2  to  4. 
The  graph  shown  below  uses  k  =  5: 


Fourier  series  for  a  square  wave 

A  square  wave  can  be  generated  by  using  the  function 


0,  if  0<x<l 

1,  //l<x<3 
0,   if  3<x<4 
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In  this  case,  the  period  T,  is  4.  Make  sure  to  change  the  value  of  variable 
SSuSS  to  4  (use:  QD        DK^J).    Function  g(X)  can  be  defined  in  the 
calculator  by  using 

DEFINE('g(X)  =  IFTE((X>1 )  AND  (X<3),1,0)') 

The  function  plotted  as  follows  (horizontal  range:  0  to  4,  vertical  range:0  to 
1.2): 


V 

1 

+ 

, ,  j 

Using  a  procedure  similar  to  that  of  the  triangular  shape  in  example  2,  above, 
you  can  find  that 


Co  = 


f(j: 


jVcfirl  =  0.5, 


and 


cCn)=f 


dX 


EDIT   CUR£   EIG  ■  EVHL  FHCTO  £IHP 


c(.n> 

3'iTl'ir  iTl'TT 

2     ^.  2 

iTi'TT  3'iTi'ir 

^22 

EDIT  1  CURS  1  EIG  -\  EVflL  |FflCTD|  SIMP 

We  can  simplify  this  expression  by  using  e'""''^  =  i"  and  e^""'^'^  =  (-i)"  to  get: 
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: DEFINE  c(n)=^^^^'^!  —* 

[  2TTTr-(-l 

 HOVRL 

EDIT  1  CURS  1  EIG     EVflL  |FflCTO|  SIMP 

+^KIP|SKIPH  H)EL  1  DEL-f|DEL  L|  inS  ■ 

The  simplification  of  the  right-hand  side  of  c(n),  above,  is  easier  done  on 
paper  (i.e.,  by  hand).  Then,  retype  the  expression  for  c(n)  as  shown  in  the 
figure  to  the  left  above,  to  define  function  c(n).  The  Fourier  series  is  calculated 
with  F(X,l<,cO),  as  in  examples  1  and  2  above,  with  cO  =  0.5.    For  example, 
for  k  =  5,  i.e.,  with  1 1  components,  the  approximation  is  shown  below: 


A  better  approximation  is  obtained  by  using  k  =  1 0,  i.e.. 


For  k  =  20,  the  fitting  is  even  better,  but  it  takes  longer  to  produce  the  graph: 
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Fourier  series  applications  in  differential  equations 

Suppose  we  want  to  use  the  periodic  square  wave  defined  in  the  previous 
example  as  the  excitation  of  an  undamped  spring-mass  system  whose 
homogeneous  equation  is:  d^y/dX^  +  0.25y  =  0. 

We  can  generate  the  excitation  force  by  obtaining  an  approximation  with  k 
=  1 0  out  of  the  Fourier  series  by  using  SW(X)  =  F(X,  1 0,0.5): 


:  DEF I  HE('SW(X)=F(X,  1 0 . . .  5^ 
HOVRL 

We  can  use  this  result  as  the  first  input  to  the  function  LDEC  when  used  to 
obtain  a  solution  to  the  system  dV^X^  +  0.25y  =  SW(X),  where  SW(X) 
stands  for  Square  Wave  function  of  X.  The  second  input  item  will  be  the 
characteristic  equation  corresponding  to  the  homogeneous  ODE  shown  above, 
i.e.,  'X'^2+0.25'  . 


With  these  two  inputs,  function  LDEC  produces  the  following  result  (decimal 
format  changed  to  Fix  with  3  decimals). 


[4. 019E-9'cC0+(0. 000,  -3^ 


DE^OL  ILHP    LHP  LDEC 


Pressing  kj/  allows  you  to  see  the  entire  expression  in  the  Equation  writer. 
Exploring  the  equation  in  the  Equation  Writer  reveals  the  existence  of  two 
constants  of  integration,  cCO  and  cCl .  These  values  would  be  calculated 
using  initial  conditions.  Suppose  that  we  use  the  values  cCO  =  0.5  and  cCl 
=  -0.5,  we  can  replace  those  values  in  the  solution  above  by  using  function 
SUBST  (see  Chapter  5).  For  this  case,  use  SUBST(ANS(1  ),cC0=0.5)  [«^, 
followed  by  SUBST(ANS(1  ),cCl  =-0.5)       .  Back  into  normal  calculator 
display  we  can  use: 
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[4.  019E-9.cC0+(0.  000,  -3\ 
:  SUESTtRHSd  .  000),cC0=0  * 

[4. 019E-9'0. 500+(0. 000/ 
:  SUBSTtRHSd .  000),cCl=-l^ 

[4 . 0 19E-9'0.500+[0.000,^ 


SOLVE  SUEST  TEKPfl 


The  latter  result  can  be  defined  as  a  function,  FW(X),  as  follows  (cutting  and 
pasting  tfie  last  result  into  tfie  command): 


[4. 019E-9'0. 500+(0. 000/ 

DEF I  He('fW(X)=(4  . 0 1 3E-3^. 

HOVRL 


SOLVE  SUeST  TEXPH 


We  can  now  plot  the  real  part  of  this  function.  Change  the  decimal  mode  to 
Standard,  and  use  the  following: 


^F-LOT 

HIDDOH  - 

FuncTion^^ 

H-Vi«H:D. 

60. 

V-VilH--l. 

H.5 

Inisf  L«h: 

Hish:D«fauU 

D<fault 

_PilHlf 

Enttr  Hini 

HUH  ind«p 

uor  vol.u« 

EDIT  1  HDD  1  DEL 

|CHDOS|ERASE|  DRAH  | 

H  EDIT  1         1         1  AUTO  lERASEI  DRAH 

The  solution  is  shown  below: 


m. 

Fourier  Transforms 

Before  presenting  the  concept  of  Fourier  transforms,  we'll  discuss  the  general 
definition  of  an  integral  transform.  In  general,  an  integral  transform  is  a 
transformation  that  relates  a  function  f(t)  to  a  new  function  F(s)  by  an 


Page  1 6-43 


integration  of  the  form  F{s)=    K{s,t)-  f{t)-  dt.    The  function  K(s,t)  is 

Ja 

known  as  the  kernel  of  the  transformation. 

The  use  of  an  integral  transform  allows  us  to  resolve  a  function  into  a  given 
spectrum  of  components.  To  understand  the  concept  of  a  spectrum,  consider 
the  Fourier  series 

fit)  =  «o  +  X  (^«  ■  +    ■  sin  co„x). 


representing  a  periodic  function  with  a  period  T.   This  Fourier  series  can  be 

00 

re-written  as  f{x)  =     +  ^  A  '  cos(g7^ x  +  ^„  ),  where 


A  =4^1+^1,  (Z>„=tan- 


for  n  =1 ,2,  ... 

The  amplitudes  A„  will  be  referred  to  as  the  spectrum  of  the  function  and  will 
be  a  measure  of  the  magnitude  of  the  component  of  f(x)  with  frequency  fn  = 
n/T.  The  basic  or  fundamental  frequency  in  the  Fourier  series  is  fo  =  1/T,  thus, 
all  other  frequencies  are  multiples  of  this  basic  frequency,  i.e.,  f^  =  n-fg.  Also, 
we  can  define  an  angular  frequency,  co^  =  2n7r/T  =  27i  f„  =  2ji-  n-fg  =  n-coo/ 
where  coq  is  the  basic  or  fundamental  angular  frequency  of  the  Fourier  series. 

Using  the  angular  frequency  notation,  the  Fourier  series  expansion  is  written 
as 

00 

fix)  =  flo  +  Z  A  •  cos(<y„x  +  ). 


CO 

=  ^0  +  X  ('^«  ■      ^nX  +  b„-  sin  co^x) 
«=i 
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A  plot  of  the  values  vs.  co^  is  the  typical  representation  of  a  discrete 
spectrum  for  o  function.  The  discrete  spectrum  will  shov^  that  the  function  has 
components  at  angular  frequencies  v/hich  are  integer  multiples  of  the 
fundamental  angular  frequency  coq. 

Suppose  that  v^e  are  faced  with  the  need  to  expand  a  non-periodic  function 
into  sine  and  cosine  components.  A  non-periodic  function  can  be  thought  of 
OS  having  an  infinitely  large  period.  Thus,  for  a  very  large  value  of  T,  the 
fundamental  angular  frequency,  Oq  =  2k/J,  becomes  a  very  small  quantity, 
say  Aco.  Also,  the  angular  frequencies  corresponding  to  (»„  =  noo  =  n-Aco, 
(n  =  1,  2,  oo),  now  take  values  closer  and  closer  to  each  other,  suggesting 
the  need  for  a  continuous  spectrum  of  values. 

The  non-periodic  function  can  be  written,  therefore,  as 

/•oo 

/W  =    [C(co)  ■  cos(a)  •  x)  +  S{co)  ■  sm(a>  ■  x)]do}, 

JO 

where 

1  (•«> 

C(a))  =  f(x)-  cos(a>  ■  x)-  dx. 

In 

and 

1     f  ™ 

S{g))  =  /(x)  •  sin(<j;  ■  x)  •  (ix 

In 

The  continuous  spectrum  is  given  by 

The  functions  C((o),  S(co),  and  A(co)  are  continuous  functions  of  a  variable  co, 
which  becomes  the  transform  variable  for  the  Fourier  transforms  defined 
below. 

Example  1  -  Determine  the  coefficients  C(ff)),  S(co),  and  the  continuous 
spectrum  A((o),  for  the  function  f(x)  =  exp(-x),  for  x  >  0,  and  f(x)  =  0,  x  <  0. 
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In  the  calculator,  set  up  and  evaluate  the  following  Integrals  to  calculate  C(co) 


and  S(fi) 


,  respectively.  CAS  modes  are  set  to  Exact  and  Real. 


1 


J27 


EDIT   CUR^   eiG  ■  EVHL  FHCTO  ilW  H  EDIT   CUR^   HIQ  ■  EVHL  FHCTD  ^IHR 


Their  results  are,  respectively: 


The  continuous  spectrum,  A(co)  is  calculated  as: 


EDIT   CURS    RIG    EVHL  FflCTD  SIMP 


Define  this  expression  as  a  function  by  using  function  DEFINE  (I  <n  Jp^  ). 
Then,  plot  the  continuous  spectrum,  in  the  range  0  <  co  <  1 0,  as: 


"v, 


V 


Definition  of  Fourier  transforms 

Different  types  of  Fourier  transforms  can  be  defined.  The  following  are  the  definitions 
of  the  sine,  cosine,  and  full  Fourier  transforms  and  their  inverses  used  in  this  Chapter: 


Fourier  sine  transform 
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Fs  {fit)}  =  F{co)  =  -  ■  [7(0  •  sin(^^  -O-dt 
Inverse  sine  transform 

F;'  {Fip)}  =  fit)  =  \y(cD)  ■  sm{o>  ■t)-dt 

Fourier  cosine  transform 

Fc  {fit))  =  F(co)  =  -  ■  [fit)  ■  cos(«  -O-dt 

Inverse  cosine  transform 

F;'  =  fit)  =  J>(«)  •  cosico  ■t)-dt 

Fourier  transform  (proper) 

V{fit))  =  Fico)  =  ^.r  fit)-e-''^ -dt 
Inverse  Fourier  transform  (proper) 

V-\Fi(o))  =  fif)=r  Fi(o)-e-''^  -dt 

J  —00 

Example  1  -  Determine  the  Fourier  transform  of  the  function  f(t)  =  exp(- 1),  for  t 
>0,  and  f(t)  =  0,  for  t<0. 

The  continuous  spectrum,  F(a)),  is  calculated  v/ith  the  integral: 

—  re-''^'^^'dt  =  \\m—  {V^'^'^^'dt 
In  -"o  In  -"o 

J  1_ 

2n  1  +  ico 

This  result  can  be  rationalized  by  multiplying  numerator  and  denominator  by 
the  conjugate  of  the  denominator,  namely,  1-ico.  The  result  is  now: 


lim^— 
2n 


1  -  exp(-(l  +  ia))£) 
l  +  ico 
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1  r  1 


CO 


-I- 


which  is  a  complex  function. 

The  absolute  value  of  the  real  and  imaginary  parts  of  the  function  can  be 
plotted  as  shown  below 


Notes: 

The  magnitude,  or  absolute  value,  of  the  Fourier  transform,  |  F((b)  |  ,  is  the 
frequency  spectrum  of  the  original  function  f(t).  For  the  example  shown  above, 
I  F((»)  I  =  l/[27i(l +co^)]^''^.  The  plot  of  |  F((fl)  |  vs.  co  was  shown  earlier. 

Some  functions,  such  as  constant  values,  sin  x,  exp(x),  x^,  etc.,  do  not  have 
Fourier  transform.  Functions  that  go  to  zero  sufficiently  fast  as  x  goes  to 
infinity  do  have  Fourier  transforms. 


Properties  of  the  Fourier  transform 

Linearity:  If  a  and  b  are  constants,  and  f  and  g  functions,  then  F{a  f  +  b-g}  = 


Transformation  of  partial  derivatives.  Let  u  =  u{x,t).  If  the  Fourier  transform 
transforms  the  variable  x,  then 


aF{f}+bF{g}. 


F{5u/5x}  =  ico  F{u},  ^dWdx"}  =  V  F{u}, 

F{eu/at}  =  eF{u}M  Ffs^u/st^}  =  d^^u}/d\^ 
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convolution:  For  Fourier  transform  applications,  the  operation  of  convolution 
is  defined  as 


(/  *  g)(x)  =  ^  •  J  /(X  -  ^)  •  g(^)  •  d^. 


Tfie  follov/ing  property  fiolds  for  convolution: 

F{f*g}  =  F{f}.F{g}. 

Fast  Fourier  Transform  (FFT) 

Thie  Fast  Fourier  Transform  is  a  computer  algoritfim  by  wfiicfi  one  can 
calculate  very  efficiently  a  discrete  Fourier  transform  (DPT).    This  algorithm 
has  applications  in  the  analysis  of  different  types  of  time-dependent  signals, 
from  turbulence  measurements  to  communication  signals. 

The  discrete  Fourier  transform  of  a  sequence  of  data  values  {X|},  j  =  0,  1, 
2,      n-1,  is  a  nev/  finite  sequence  {XJ,  defined  as 


Y  n-1 

=  —'y\x-Qxp{-i-27ikj/n),       A:  =  0,1,2,...,« -1 
n 


7=0 

The  direct  calculation  of  the  sequence     involves  n^  products,  which  would 
involve  enormous  amounts  of  computer  (or  calculator)  time  particularly  for 
large  values  of  n.  The  Fast  Fourier  Transform  reduces  the  number  of 
operations  to  the  order  of  n  log2n.    For  example,  for  n  =  1 00,  the  FFT 
requires  about  664  operations,  while  the  direct  calculation  would  require 
1 0,000  operations.  Thus,  the  number  of  operations  using  the  FFT  is  reduced 
by  a  factor  of  1 0000/664  »  1 5. 

The  FFT  operates  on  the  sequence  {Xj}  by  partitioning  it  into  a  number  of 
shorter  sequences.  The  DFT's  of  the  shorter  sequences  are  calculated  and 
later  combined  together  in  a  highly  efficient  manner.    For  details  on  the 
algorithm  refer,  for  example,  to  Chapter  12  in  Newland,  D.E.,  1993,  "An 
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Introduction  to  Random  Vibrations,  Spectral  &  Wavelet  Analysis  -  Third 
Edition,"  Longman  Scientific  and  Technical,  New  York. 

The  only  requirement  for  the  application  of  the  FFT  is  that  the  number  n  be  a 
power  of  2,  i.e.,  select  your  data  so  that  it  contains  2,  4,  8,  16,  32,  62,  etc., 
points. 

Examples  of  FFT  applications 

FFT  applications  usually  involve  data  discretized  from  a  time-dependent  signal. 
The  calculator  can  be  fed  that  data,  say  from  a  computer  or  a  data  logger,  for 
processing.   Or,  you  can  generate  your  own  data  by  programming  a 
function  and  adding  a  few  random  numbers  to  it. 

Example  1  -  Define  the  function  f(x)  =  2  sin  {3x)  +  5  cos(5x)  +  0.5* RAND, 
where  RAND  is  the  uniform  random  number  generator  provided  by  the 
calculator.  Generate  1 28  data  points  by  using  values  of  x  in  the  interval 
(0,1  2.8).  Store  those  values  in  an  array,  and  perform  a  FFT  on  the  array. 

First,  we  define  the  function  f(x)  as  a  RPN  program: 

«  ^  X  '2*SiN(3*x)  +  5*COS{5*x)'  EVAL  RAND  5  *  +  ^NUM  » 

and  store  this  program  in  variable  nSEiSI.    Next,  type  the  following  program  to 
generate  2""  data  values  between  a  and  b.  The  program  will  take  the  values 
of  m,  a,  and  b: 

«  ^  m  a  b  «  '2'^m'  EVAL  ->  n  «  '{b-a)/(n+l )'  EVAL  ^  Dx  «  1  n  FOR  j 
'a+(j-l)*Dx' EVALf  NEXT  n  ^ARRY  »  »  »  » 

Store  this  program  under  the  name  GDATA  (Generate  DATA).  Then,  run  the 
program  for  the  values,  m  =  5,  a  =  0,  b  =  1 00.  In  RPN  mode,  use: 

CX3      (X]  CED  CID      CS  EiiEIE! 

The  figure  below  is  a  box  plot  of  the  data  produced.  To  obtain  the  graph, 

first  copy  the  array  just  created,  then  transform  it  into  a  column  vector  by 
using:  OBJ^  CTD  C+D  ^ARRY  (Functions  OBJ^  and  ^ARRY  are  available 
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in  the  command  catalog,  QiD— ^  )•  Store  the  array  into  variable  ZDAT  by 
using  function  STOS  (also  available  through  I    J  cat  ).    Select  Bar  in  the 
TYPE  for  graphs,  change  the  view  window  to  H-VIEW:  0  32,  V-VIEW:  -10  10, 
and  BarWidth  to  1 .    Press  EESESjCW]  to  return  to  normal  calculator  display. 


4 

ikul 

To  perform  the  FFT  on  the  array  in  stack  level  1  use  function  FFT  available  in 
the  MTH/FFT  menu  on  array  2DAT:  ESM  FFT.   The  FFT  returns  an  array  of 
complex  numbers  that  are  the  arrays  of  coefficients  X|<  of  the  DFT.  The 
magnitude  of  the  coefficients     represents  a  frequency  spectrum  of  the 
original  data.  To  obtain  the  magnitude  of  the  coefficients  you  could  transform 
the  array  into  a  list,  and  then  apply  function  ABS  to  the  list.  This  is 
accomplished  by  using:  OBJ^   (W)  C5]  ^LIST  [^a^ 

Finally,  you  can  convert  the  list  back  to  a  column  vector  to  be  stored  in  EDAT, 
as  follows:  OBJ^  UJ        CU  ^LIST  ^ARRY  STOS 

To  plot  the  spectrum,  follow  the  instructions  for  producing  a  bar  plot  given 
earlier.  The  vertical  range  needs  to  be  changed  to  -1  to  80.  The  spectrum  of 
frequencies  is  the  following: 


■.Im.I.IIiI 

11.11 

The  spectrum  shows  two  large  components  for  two  frequencies  (these  are  the 
sinusoidal  components,  sin  (3x)  and  cos(5x)),  and  a  number  of  smaller 
components  for  other  frequencies. 
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Example  2  -  To  produce  the  signal  given  the  spectrum,  we  modify  the 
program  GDATA  to  include  an  absolute  value,  so  that  it  reads: 

«  ^  m  0  b  «  '2'^m'  EVAL  ^  n  «  '(b-a)/(n+l )'  EVAL  ^  Dx  «  1  n  FOR  j 
'a+(j-l)*Dx' EVALf  ABS  NEXT  n  ^ARRY  »  »  »  » 

Store  this  version  of  the  program  under  GSPEC  (Generate  SPECtrum).  Run  the 
program  with  m  =  6,  a  =  0,  b  =  100.  In  RPN  mode,  use: 
CS  CD  iSl  S  IfiM 

Press  [INTER}  when  done,  to  keep  an  additional  copy  of  the  spectrum  array. 
Convert  this  row  vector  into  a  column  vector  and  store  it  into  SDAT.  Following 
the  procedure  for  generating  a  bar  plot,  the  spectrum  generated  for  this 
example  looks  as  shown  below.  The  horizontal  range  in  this  case  is  0  to  64, 
while  the  vertical  range  is  -1  to  10: 


v 

ill 

1,1 

h 

1 

.1 

1.1 

1 

,1 

Illll 

n 

To  reproduce  the  signal  whose  spectrum  is  shown  ,  use  function  IFFT.  Since 
we  left  a  copy  of  the  spectrum  in  the  stack  (a  row  vector),  all  you  need  to  do  if 
find  function  IFFT  in  the  MTH/FFT  menu  or  through  the  command  catalog, 
(j^l  CAT  .  As  on  alternative,  you  could  simply  type  the  function  name,  i.e., 
type  (^™)(At^(T](7](T](r](«^.  The  signal  is  shown  as  an  array  (row  vector) 
with  complex  numbers.  We  are  interested  only  in  the  real  part  of  the  elements. 
To  extract  the  real  part  of  the  complex  numbers,  use  function  RE  from  the 
CMPLX  menu  (see  Chapter  4),  e.g.,  type  [^wM|(^Z™](g(|](w7?K].  What  results  is 
another  row  vector.  Convert  it  into  a  column  vector,  store  it  into  EDAT,  and 
plot  a  bar  plot  to  show  the  signal.  The  signal  for  this  example  is  shown  below, 
using  a  horizontal  range  of  0  to  64,  and  a  vertical  range  of  -1  to  1 : 
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V 

Except  for  a  large  peak  at  t  =  0,  the  signal  is  mostly  noise.  A  smaller  vertical 
scale  (-0.5  to  0.5)  shows  the  signal  as  follows:  


V 

1 1,1,11 

1 

u 

^ 

r'lir  1 

ri 

1  1  |i  '  1 

1 

Solution  to  specific  second-order  differential  equations 

In  this  section  we  present  and  solve  specific  types  of  ordinary  differential 
equations  whose  solutions  are  defined  in  terms  of  some  classical  functions, 
e.g.,  Bessel's  functions,  Hermite  polynomials,  etc.  Examples  are  presented  in 
RPN  mode. 

The  Cauchy  or  Euler  equation 

An  equation  of  the  form  x'^  (d'^y/dx^)  +  a-x-  (dy/dx)  +  b  y  =  0,  where  a  and  b 
are  real  constants,  is  known  as  the  Cauchy  or  Euler  equation.  A  solution  to 

the  Cauchy  equation  can  be  found  by  assuming  that  y(x)  =  x". 
Type  the  equation  as:  'x'^2*dldly(x)+a*x*dly(x)+b*y(x)=0'  [inter) 
Then,  type  and  substitute  the  suggested  solution:  'y(x)  =  x'^n'  [inter]  iMll^il 

The  result  is:  'x'^2*(n*(x'^(n-l -1  )*(n-l  )))+a*x*(n*x'^(n-l  jj+b^x'^n  =0,  which 
simplifies  to  'n*(n-l  )*x'^n+a*n*x'^n+b*x'^n  =  0'.    Dividing  by  x'^n,  results  in 
an  auxiliary  algebraic  equation:  'n*{n-l  )+a*n+b  =  0',  or. 

+  (a-l)-n  +  b  =  0 . 

•  If  the  equation  has  two  different  roots,  say  n,  and  n2,  then  the  general 
solution  of  this  equation  is  y(x)  =  K,  x  "i  +  K2  X  "2- 

•  If  b  =  {l-a)V4,  then  the  equation  has  a  double  root  ni  =  n2  =  n  = 
(l-a)/2,  and  the  solution  turns  out  to  be  y(x)  =  (K,  +  K2-ln  x)x". 
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Legendre's  equation 

An  equation  of  the  form  (l-x^)-(d^y/dx^)-2-x-  (dy/dxj+n-  (n+1)  -y  =  0,  where  n 
is  a  real  number,  is  known  as  the  Legendre's  differential  equation.  Any 
solution  for  this  equation  is  known  as  a  Legendre's  function.  When  n  is  a 
nonnegative  integer,  the  solutions  are  called  Legendre's  polynomials. 
Legendre's  polynomial  of  order  n  is  given  by 

p  (x)  =  y  (-l)"  (2w-2m)!  _^„_2„ 

„=o  2  "  •  ml-{n  -  m)  \-(n  —  2m) ! 

(2n)\  (2n-2)\ 

'  Ji-  '  Ji  I     ...  . . 


2"  2"  •!!•(« -!)!(« -2)! 

where  M  =  n/2  or  (n-l)/2,  whichever  is  an  integer. 

Legendre's  polynomials  are  pre-programmed  in  the  calculator  and  can  be 
recalled  by  using  the  function  LEGENDRE  given  the  order  of  the  polynomial,  n. 

The  function  LEGENDRE  can  be  obtained  from  the  command  catalog 
(Cri3_c47;  )  or  through  the  menu  ARITHMETIC/POLYNOMIAL  menu  (see 
Chapter  5).  In  RPN  mode,  the  first  six  Legendre  polynomials  are  obtained  as 
follows: 


0  LEGENDRE,  result 

1  LEGENDRE,  result 

2  LEGENDRE,  result 

3  LEGENDRE,  result 

4  LEGENDRE,  result 


1,                                i.e.,  Po(x)  =  1.0. 

'X',                               i.e.,  Pi(x)  =  x. 

'(3*X'^2-l)/2',                i.e.,  PjIx)  =  (3x2-1  )/2. 

'(5*X'^3-3*X)/2',             i.e.,  P3(x)  ={5x3-3x)/2. 
'(35*X'^4-30*X^2+3)/8',  i.e., 
P4(x)  =(35x^-30x2-i-3)/8. 
5  LEGENDRE,  result:  '(63*X'^5-70*X'^3-i-l  5*X)/8',  i.e., 
P5(x)  =(63x^-70x3-1-1 5x)/8. 


The  ODE   (l-x2)-(dVdx')-2  x-  (dy/dx)+[n-  (n+l)-mV(l-x')]  -y  =  0,  has  for 
solution  the  function  y(x)  =  Pn'^(x)=  (]-xY/^-(d"'Pn/dx'").  This  function  is 
referred  to  as  an  associated  Legendre  function. 
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Bessel's  equation 

The  ordinary  differential  equation  x^-(d^y/dx^)  +  x-  (dy/dx)+  (x^-v^)  -y  =  0, 
wfiere  tfie  parameter  v  is  a  nonnegative  real  number,  is  known  as  Bessel's 
differential  equation.  Solutions  to  Bessel's  equation  are  given  in  terms  of 
Bessel  functions  of  tfie  first  kind  of  order  v: 

iT-o2'"'"''-w!-r(v  +  »7  +  l) 

wfiere  v  is  not  an  integer,  and  tfie  function  Gamma  r(a)  is  defined  in  Cfiapter 
3. 

If  V  =  n,  an  integer,  the  Bessel  functions  of  the  first  kind  for  n  =  integer  are 
defined  by 


Regardless  of  whether  we  use  v  (non-integer)  or  n  (integer)  in  the  calculator, 
we  can  define  the  Bessel  functions  of  the  first  kind  by  using  the  following  finite 
series: 


EDITlCUR^I  eiG  I  EVHL  IFHCTOI  £IHP 


Thus,  we  have  control  over  the  function's  order,  n,  and  of  the  number  of 
elements  in  the  series,  k.  Once  you  hove  typed  this  function,  you  can  use 
function  DEFINE  to  define  function  J(x,n,k).  This  will  create  the  variable  SeB 
in  the  soft-menu  keys.  For  example,  to  evaluate  J3(0.1)  using  5  terms  in  the 
series,  calculate  J(0. 1,3,5),  i.e.,  in  RPN  mode:  ^[X^ClDCX^ClDCIDIiSlil 
The  result  is  2.08203 157E-5. 
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If  you  want  to  obtain  an  expression  for  Jo(x)  witfi,  say,  5  terms  in  the  series, 
use  J(x,0,5).   The  result  is 

'l-0.25*x'^3+0.015625*xM-4.3403777E-4*x'^6+6.782168E-6*x'^8- 

6.78168*x'^10'. 

For  non-integer  values  v,  the  solution  to  the  Bessel  equation  is  given  by 

y(x)  =  KvJv(x)+K2J.v(x). 

For  integer  values,  the  functions  Jn(x)  and  J-n(x)  are  linearly  dependent,  since 

Jn(x)  =  (-lMn(x), 

therefore,  we  cannot  use  them  to  obtain  a  general  function  to  the  equation. 
Instead,  we  introduce  the  Bessel  functions  of  the  second  kind  defined  as 

Yv(x)  =  [Jv(x)  cos  VTl  -  J_v(x)]/sin  V7I, 

for  non-integer  v,  and  for  n  integer,  with  n  >  0,  by 


i;W  =  --/„W-(in^+r)+— -Z 


•X 


«  n-l 


(n-m-l)\  2m 


where  y  is  the  Euler  constant,  defined  by 

y  =  Iim[l  +  -  +  -  +  ...  +  -- Inr]  «  0.57721566490..., 

r^oo      2    3  r 

and  h^  represents  the  harmonic  series 

,11  1 

2    3  m 

For  the  case  n  =  0,  the  Bessel  function  of  the  second  kind  is  defined  as 

2 


n 


J,  (X) .  (In  -  +  r)  +  y  — -f 

"  2         ;fT5  2''"-(w!)' 
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With  these  definitions,  a  general  solution  of  Bessel's  equation  for  all  values  of 
V  is  given  by  y(x)  =  K,  Jv(x)+K2  Yv{x). 


In  some  instances,  it  is  necessary  to  provide  complex  solutions  to  Bessel's 
equations  by  defining  the  Bessel  functions  of  the  third  kind  of  order  v  as 

H„'^'(x)  =Jv(x)+i.Yv(x),  and  Hj2)(x)  =  J,(x)-i.Y,(x), 

These  functions  are  also  knov/n  as  the  first  and  second  Hankel  functions  of 
order  v. 

In  some  applications  you  may  also  have  to  utilize  the  so-called  modified 
Bessel  functions  of  the  first  kind  of  order  v  defined  as  lv(x)=  i  ^-Jvli'x),  where  i  is 
the  unit  imaginary  number.  These  functions  are  solutions  to  the  differential 
equation  x^-(dV/dx^)  +  x-  (dy/dx)-  (x^+v^)  -y  =  0. 

The  modified  Bessel  functions  of  the  second  kind, 

Kv(x)  =  (n/2)il  (x)-lv  (x)]/sin  vtt, 

are  also  solutions  of  this  ODE. 

You  can  implement  functions  representing  Bessel's  functions  in  the  calculator 
in  a  similar  manner  to  that  used  to  define  Bessel's  functions  of  the  first  kind, 
but  keeping  in  mind  that  the  infinite  series  in  the  calculator  need  to  be 
translated  into  a  finite  series. 

Chebyshev  or  Tchebycheff  polynomials 

The  functions  T„(x)  =  cos(n-cos^  x),  and    U„(x)  =  sin[(n-l-l)  cos"^  x]/(l -x^)'''^,  n 
=  0,  1 ,  ...  are  called  Chebyshev  or  Tchebycheff  polynomials  of  the  first  and 
second  kind,  respectively.  The  polynomials  Tn(x)  are  solutions  of  the 
differential  equation  (l-x^)-(d^y/dx^)  -  x-  (dy/dx)  +  n^-y  =  0. 

In  the  calculator  the  function  TCHEBYCHEFF  generates  the  Chebyshev  or 
Tchebycheff  polynomial  of  the  first  kind  of  order  n,  given  a  value  of  n  >  0.  If 
the  integer  n  is  negative  (n  <  0),  the  function  TCHEBYCHEFF  generates  a 
Tchebycheff  polynomial  of  the  second  kind  of  order  n  v/hose  definition  is 
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Un(x)  =  sin(n-arccos(x))/sin(arccos(x)). 
You  can  access  the  function  TCHEBYCHEFF  through  the  command  catalog 

The  first  four  Chebyshev  or  Tchebycheff  polynomials  of  the  first  and  second 
kind  are  obtained  as  follows: 


0  TCHEBYCHEFF,  result:  1, 

i.e.. 

To(x) 

=  1.0. 

-0  TCHEBYCHEFF,  result:  1, 

i.e.. 

Uo(x) 

=  1.0. 

1  TCHEBYCHEFF,  result:  X, 

i.e.. 

Ti(x) 

=  X. 

-1  TCHEBYCHEFF,  result:  1, 

i.e.. 

U,(x) 

=  1.0. 

2  TCHEBYCHEFF,  result:  '2*X^2■^, 

i.e.. 

T2(x) 

=2x2-1 . 

-2  TCHEBYCHEFF,  result:  '2*X', 

i.e.. 

U2(X) 

=2x. 

3  TCHEBYCHEFF,  result:  '4*X'^3-3*X', 

i.e.. 

T3(x) 

=  4x2-3x. 

-3  TCHEBYCHEFF,  result:  '4*X'^2-T, 

i.e.. 

U3(X) 

=  4x2-1 . 

Laguerre's  equation 

Laguerre's  equation  is  the  second-order,  linear  ODE  of  the  form  x-(d^y/dx^] 
+(l-x)-  (dy/dx)  +  n  y  =  0.  Laguerre  polynomials,  defined  as 

Lq{x)  =  1,    L„(x)  =  —  —  ,n  =  l,2,..., 

n\  ax 

are  solutions  to  Laguerre's  equation.  Laguerre's  polynomials  can  also  be 
calculated  with: 


n{n-X)    2  (-1)"  „ 

=  \-n-x  +  —  --x  - + +  - — —-x 

4  n\ 

The  term 


=  C{n,  m) 


m\{n  -  m)\ 
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is  the  m-th  coefficient  of  tfie  binomial  expansion  (x+y)".  It  also  represents  the 
number  of  combinations  of  n  elements  taken  m  at  a  time.  This  function  is 
available  in  the  calculator  as  function  COMB  in  the  MTH/PROB  menu  (see 
also  Chapter  1 7). 

You  can  define  the  following  function  to  calculate  Laguerre's  polynomials: 

m=0 

When  done  typing  it  in  the  equation  writer  press  use  function  DEFINE  to 
create  the  function  L(x,n)  into  variable  SS3S!  . 

To  generate  the  first  four  Laguerre  polynomials  use,  L(x,0),  L(x,  1),  L(x,2),  L(x,3). 
The  results  are: 

Lo(x)=  . 

Li(x)  =  l-x. 

L2(x)=  l-2x+  0.5x2 

L3(x)  =  l-3x+ 1.5x^-0.1 6666... x^. 

Weber's  equation  and  Hermite  polynomials 

Weber's  equation  is  defined  as  6^y/dx^+{n+^ /2-y.^/4)y  =  0,  for  n  =  0,  1, 
2,  ...  A  particular  solution  of  this  equation  is  given  by  the  function  ,  y(x)  = 
exp(-xV4)H*(x/V2),  where  the  function  H*(x)  is  the  Hermite  polynomial: 

H*  =  \,    H„*(x)  =  (-ire^'^(e-''),    n  =  l,2,.. 

ax 

In  the  calculator,  the  function  HERMITE,  available  through  the  menu 
ARITHMETIC/POLYNOMIAL.  Function  HERMITE  takes  as  argument  an  integer 
number,  n,  and  returns  the  Hermite  polynomial  of  n-th  degree.  For  example, 
the  first  four  Hermite  polynomials  are  obtained  by  using: 
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0  HERMITE,  result:  1, 

1  HERMITE,  result:  '2*X', 

2  HERMITE,  result:  '4*X'^2-2', 

3  HERMITE,  result:  '8*X'^3-1 2*X', 


i.e.,  Ho*  =  1 . 
i.e.,  H/  =  2x. 
i.e.,  Hj*  =  4x^-2. 
i.e.,  H3*  =  8x3-1 2x. 


Numerical  and  graphical  solutions  to  ODEs 

Differential  equations  tfiat  cannot  be  solved  analytically  can  be  solved 
numerically  or  grapfiically  as  illustrated  below. 

Numerical  solution  of  first-order  ODE 

Through  the  use  of  the  numerical  solver  [{j^]num.slv  )^  you  can  access  an  input 
form  that  lets  you  solve  first-order,  linear  ordinary  differential  equations.  The 
use  of  this  feature  is  presented  using  the  following  example.  The  method  used 
in  the  solution  is  a  fourth-order  Runge-Kutta  algorithm  preprogrammed  in  the 
calculator. 


Example  1  -  Suppose  we  want  to  solve  the  differential  equation,  dv/dt  =  -1 .5 
4  at  t  =  0.  We  are  asked  to  find  v  for  t  =  2. 


v^/^,  with  V 


First,  create  the  expression  defining  the  derivative  and  store  it  into  variable 
EQ.  The  figure  to  the  left  shows  the  ALG  mode  command,  while  the  right- 
hand  side  figure  shows  the  RPN  stack  before  pressing  [stc»}  . 


:-1.5-JytEQ 

3: 

-1.5-JU 

l: 

'EQ' 

Then,  enter  the  NUMERICAL  SOLVER  environment  and  select  the  differential 
equation  solver:  (.    }num.sly       lillEniil  .  Enter  the  following  parameters: 


SOLVE  V  (T)=F(T,VJ 

f-  '-1.5*-J"v' 
Ind<p:t    lnit:0        Final  2 
SoVn:  ij    Ini't:4  Final.| 
T*  I :  .  000 1   itip :  Df  1 1     _  J^iFf 

frm  SOLVE  f*r  finol  f*ln  oalm 


iniT+  SOLVE 
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To  solve,  press:  ESS!S  (wait)  IHIMl.  The  result  is  0.2499  «  0.25.  Press  SESSB. 
Solution  presented  as  a  table  of  values 

Suppose  we  wanted  to  produce  a  table  of  values  of  v,  for  t  =  0.00,  0.25, 
2.00,  we  will  proceed  as  follows: 

First,  prepare  a  table  to  write  down  your  results.  Write  down  in  your  table  tfie 
step-by-step  results:   


t 

V 

0.00 

0.00 

0.25 

2.00 

Next,  witfiin  the  SOLVE  environment,  change  the  final  value  of  the 
independent  variable  to  0.25,  use  : 

.25lllyll^ll  CDCE)  ^ilililiilii  (wait)  lLil!yijlijl 
(Solves  for  v  at  t  =  0.25,  v  =  3.285  ....  ) 
iEIll!  3';""=^  .  5  "tICDCD (wait)  IITIT:: 

(Changes  initial  value  of  t  to  0.25,  and  final  value  of  t  to  0.5,  solve  for  v(0.5) 
=  2.640...) 

iESSS  ISMiCI^  .75  :::ril(X)CE?ESI!Hs  (wait) 

(Changes  initial  value  of  t  to  0.5,  and  final  value  of  t  to  0.75,  solve  for  v(0.75) 
=  2.066...) 

iESSi  lEillEiGEI^  1 1EI3S  CD  CD         (wait)  mM 

(Changes  initial  value  of  t  to  0.75,  and  final  value  of  t  to  1,  solve  for  v(l)  = 
1.562...) 

Repeat  for  t  =  1 .25,  1 .50,  1 .75,  2.00.  Press  iulli  after  viewing  the  last  result 
in  tSSS.  To  return  to  normal  calculator  display,  press  I  on  J  or  (.wxtjBBSB.  The 
different  solutions  will  be  shown  in  the  stack,  with  the  latest  result  in  level  1 . 

The  final  results  look  as  follows  (rounded  to  the  third  decimal): 
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t 

V 

0.00 

4.000 

0.25 

3.285 

0.50 

2.640 

0.75 

2.066 

1.00 

1.562 

1.25 

1.129 

1.50 

0.766 

1.75 

0.473 

2.00 

0.250 

Graphical  solution  of  first-order  ODE 

When  we  can  not  obtain  a  closed-form  solution  for  tfie  integral,  we  can 
always  plot  tfie  integral  by  selecting  Dif  f  Eq  in  the  TYPE  field  of  the  PLOT 
environment  as  follows:  suppose  that  we  want  to  plot  the  position  x(t)  for  a 
velocity  function  v(t)  =  exp(-t^),  with  x  =  0  at  t  =  0.  We  know  there  is  no 
closed-form  expression  for  the  integral,  however,  we  know  that  the  definition 
of  v(t)  is  dx/dt  =  exp(-f). 

The  calculator  allows  for  the  plotting  of  the  solution  of  differential  equations  of 
the  form  Y'(T)  =  F(T,Y).  For  our  case,  we  let  Y  =  x  and  T  =  t,  therefore,  F(T,Y) 
=  f(t,  x)  =  exp(-t^).  Let's  plot  the  solution,  x(t),  for  t  =  0  to  5,  by  using  the 
following  keystroke  sequence: 

•  [jnj  JMD  (simultaneously,  if  in  RPN  mode)  to  enter  PLOT  environment 

•  Highlight  the  field  in  front  of  TYPE,  using  the  i^^*^^  keys.    Then,  press 
iflHSSa,  and  highlight  Dif  f  Eq,  using  the  (^^"s^?  keys.  Press  lilyllli. 

•  Change  field  F:  to 'EXP(-r  2)' 

•  Make  sure  that  the  following  parameters  are  set  to:  H-VAR:  0,  V-VAR: 

1 

•  Change  the  independent  variable  to  t  . 

•  Accept  changes  to  PLOT  SETUP:  (W]  IEI3S 

•  (JTjjm^  (simultaneously,  if  in  RPN  mode).    To  enter  PLOT  WINDOW 
environment 

•  Change  the  horizontal  and  vertical  view  window  to  the  following  settings: 

H-VIEW:   -1         5;     V-VIEW:   -1  1.5 
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Also,  use  the  following  values  for  the  remaining  parameters:  Init:  0,  Final: 
5,  Step:  Default,  Tol:  0.0001,  init-Soln:  0 
To  plot  the  graph  use:  03311 


ZOOM  |(K^V) 


EDIT  CHnCL 


When  you  observe  the  graph  being  plotted,  you'll  notice  that  the  graph  is  not 
very  smooth.  That  is  because  the  plotter  is  using  a  time  step  that  may  be  a  bit 
large  for  a  smooth  graph.  To  refine  the  graph  and  make  it  smoother,  use  a 
step  of  0.1.  Press  WllfW^  and  change  the  Step  :  value  to  0.1,  then  use 
"" ""l'™"  once  more  to  repeat  the  graph.  The  plot  will  take  longer  to  be 
completed,  but  the  shape  is  definitely  smoother  than  before.  Try  the  following: 
liMi  (W]  EESa  IGH3II  to  see  axes  labels  and  range. 


1.5 


Notice  that  the  labels  for  the  axes  are  shown  as  0  (horizontal,  for  t)  and  1 
(vertical,  for  x).  These  are  the  definitions  for  the  axes  as  given  in  the  PLOT 
SETUP  window  (QDi™, )  i.e.,  H-VAR:  0,  and  V-VAR:  1 .  To  see  the  graphical 
solution  in  detail  use  the  following: 


[nxt }Inxt ]ImM1    To  recover  menu  and  return  to  PICT  environment. 
n(:™)ll  To  determine  coordinates  of  any  point  on  the  graph. 

Use  the  C3DCD  keys  to  move  the  cursor  around  the  plot  area.  At  the  bottom 
of  the  screen  you  will  see  the  coordinates  of  the  cursor  as  (X,Y),  i.e.,  the 
calculator  uses  X  and  Y  as  the  default  names  for  the  horizontal  and  vertical 
axes,  respectively.  Press  (,A/xrj|i33!il  to  recover  the  menu  and  return  to  the 
PLOT  WINDOW  environment.  Finally,  press  I  oi^  J  to  return  to  normal  display. 
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Numerical  solution  of  second-order  ODE 

Integration  of  second-order  ODEs  can  be  accomplished  by  defining  the 
solution  OS  a  vector.  As  on  example,  suppose  that  a  spring-mass  system  is 
subject  to  a  damping  force  proportional  to  its  speed,  so  that  the  resulting 

differential  equation  is:  — ^  =  —1 8.75  •  x  —  1 .962  

dt  dt 


or. 


x"  =  -  18.75  X-  1.962  x'. 


subject  to  the  initial  conditions,  v  =  x'  =  6,  x  =  0,  at  t  =  0.  We  want  to  find  x, 
x'  at  t  =  2. 


Re-write  the  ODE  as:  w'  =  Aw,  where  w  =  [  x  x'  ]\  and  A  is  the  2  x  2 
matrix  shown  below. 

0  1 
■18.75  -1.962 


X 

_x'_ 

X 

x'_ 

The  initial  conditions  are  now  written  as  w  =  [0  6]\  for  t  =  0.  (Note:  The 
symbol  [  Y  means  the  transpose  of  the  vector  or  matrix). 

To  solve  this  problem,  first,  create  and  store  the  matrix  A,  e.g.,  in  ALG  mode: 
■[-IS^.75  -l/gfeJ^'^ 

r    0  11 

 L-1S.75  -1.362[ 

Then,  activate  the  numerical  differential  equation  solver  by  using:  C5D  '•^■slv 

IliilGli  .    To  solve  the  differential  equation  with  starting  time  t  =  0  and 
final  time  t  =  2,  the  input  form  for  the  differential  equation  solver  should  look 
as  follows  (notice  that  the  Init:  value  for  the  Soln:  is  a  vector  [0,  6]): 
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SOLVE  V  (T)=F(T,VJ 
f-  R*W 

Ind<p:t    lnit:0        Final  2 
SoVn:  \j    Init^CQ,  „,  Final. ^1 
T*  I :  .  000 1   St<p :  Df  1 1     _  J^iFf 

frm  SOLVE  f*r  final  f*ln  oalm 


iniT+  SOLVE 


Press  l^mni  (wait) 
.6271...],  i.e.,  x(2) 
return  to  SOLVE  environment 


iiiEEH   to  solve  for  w(t=2).  The  solution  reads  [.16716...  - 
0.16716,  and  x'(2)  =  v(2)  =  -0.6271 .  Press  HIUS  to 


Solution  presented  as  a  table  of  values 

In  the  previous  example  we  were  interested  only  in  finding  the  values  of  the 
position  and  velocity  at  a  given  time  t.  If  we  wanted  to  produce  a  table  of 
values  of  x  and  x',  for  t  =  0.00,  0.25,  2.00,  we  will  proceed  as  follows: 
First,  prepare  a  table  to  write  down  your  results: 


0.00 


0.00 


6.00 


0.25 


2.00 


Next,  within  the  SOLVE  environment,  change  the  final  value  of  the 
independent  variable  to  0.25,  use: 

^.251111  CD  CD  iiiSaiiia  (wait)  Oljijjj 
(Solves  for  w  at  t  =  0.25,  w  =  [0.968  1 .368].  ) 

IKTIVB  :tm:-3:-3!'b  /tn,       £r  !S!'?rri!S!         /-T-^  Si:;:!';'!"!!""":!  /, .  :i\  ir:riir;ir;i 

oiAM  auaiMi  r -^^  .  z>  mui^  {y)      ^^usA^  (v/a\\l  itiiijcsst 

(Changes  initial  value  of  t  to  0.25,  and  final  value  of  t  to  0.5,  solve  again  for 
w(0.5)  =  [0.748  -2.616]) 

il!!:::U:il!!  !!L:!j.!L:!L!!M!  (<A>)  .  /  Q  iau.fl||(  yj  (       gaii.a j.3  (WOlt)  ILilitJlJI 

(Changes  initial  value  of  t  to  0.5,  and  final  value  of  t  to  0.75,  solve  again  for 
w(0.75)  =  [0.0147  -2.859]) 

 ' 1  Eil  CD  CD  !'-:°:T:!":!  (wait)  ininm 

(Changes  initial  value  of  t  to  0.75,  and  final  value  of  t  to  1,  solve  again  for 
w(l)  =  [-0.469  -0.607]) 
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Repeat  for  t  =  1 .25,  1 .50,  1 .75,  2.00.  Press  HISIjII  after  viewing  tfie  last  result 
in  OEEiBi.  To  return  to  normal  calculator  display,  press  I  on  J  or  [wJiBSi.  Tfie 
different  solutions  will  be  sfiown  in  tfie  stack,  witfi  tfie  latest  result  in  level  1 . 
Tfie  final  results  look  as  follows: 


t 

X 

x' 

t 

X 

x" 

0.00 

0.000 

6.000 

1.25 

-0.354 

1.281 

0.25 

0.968 

1.368 

1.50 

0.141 

1.362 

0.50 

0.748 

-2.616 

1.75 

0.227 

0.268 

0.75 

-0.015 

-2.859 

2.00 

0.167 

-0.627 

1.00 

-0.469 

-0.607 

Graphical  solution  for  a  second-order  ODE 

Start  by  activating  the  differential  equation  numerical  solver,  I  r»  J  Mt.sLv 
<^  KliS  .  Tfie  SOLVE  screen  sfiould  look  like  this: 


SOLVE  V  (T)=F(T,VJ  WM 

Ind<p:t    lnit:0        Final  2 
S«l.n:  \j    Ini't:[Q,  „,  Final. 
T*  I :  .  000  1    St«p  :  Df  1 1     _  Stiff 

frill  SOLVE  f*r  final  f*ln  oalu« 


iniT+  SOLVE 


Notice  that  the  initial  condition  for  the  solution  (Soln:  w  lnit:[0.,  ...)  includes 
the  vector  [0,  6].  Press  (mr}  ISZISS. 

Next,  press  dDie^  (simultaneously,  if  in  RPN  mode)  to  enter  the  PLOT 
environment.  Highlight  the  field  in  front  of  TYPE,  using  the  (^^3?  keys. 
Then,  press  IIEMI5I,  and  highlight  Diff  Eq,  using  the  (^^^^^3? keys.  Press 
SEmS.   Modify  the  rest  of  the  PLOT  SETUP  screen  to  look  like  this: 


^^^^FLOT  SETUFg 

F:H<H 

H-Vlf-O  V-Var:l 

_Stiff 

H-Tich:lD.  V-Tich:lD. 

^fiJ.ll.1 

ch**f<  ■tap<  *F  put 

|HXESi|ERASE|  DRHH 
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Notice  that  the  option  V-Var:  is  set  to  1,  indicating  that  the  first  element  in  the 
vector  solution,  namely,  x',  is  to  be  plotted  against  the  independent  variable  t. 
Accept  changes  to  PLOT  SETUP  by  pressing  (W)  IBSffl. 

Press  [JT]  JM^L  (simultaneously,  if  in  RPN  mode)  to  enter  the  PLOT  WINDOW 
environment.  Modify  this  input  form  to  look  like  this: 


^^F-LOT 

HinDOH  -  DIFF 

H-Vi«H:SI 

2.5 

V-Vi<H:-5. 

5. 

Init:  0. 

Finol.: 

2.5 

.1  T*l 

: .0001 

Enttr  HiniHUH  h^riz^ntol. 

To  plot  the  x'  vs.  t  graph  use:  S133aa  EISIj  .   The  plot  of  x'  vs.  t  looks  like  this: 


Hi 

ZOOM  KK^V) 

1     1  1 

EDIT  ICHnCL 

To  plot  the  second  curve  we  need  to  use  the  PLOT  SETUP  input  form  once, 
more.  To  reach  this  form  from  the  graph  above  use:  SaSIIm 
:::!I::H:ljnJio5D  (simultaneously,  if  in  RPN  mode) .  Change  the  value  of  the 
V-Var:  field  to  2,  and  press  lULLLJ  (do  not  press  133333  or  you  would  loose  the 
graph  produced  above).  Use:  ilMiSII  [nxtJ  77, - to  see  axes  labels  and 
range.  Notice  that  the  x  axis  label  is  the  number  0  (indicating  the 
independent  variable),  while  the  y-axis  label  is  the  number  2  (indicating  the 
second  variable,  i.e.,  the  last  variable  plotted).  The  combined  graph  looks 
like  this: 


5. 

-5. 

Press  [NXTjlNXT]  utjlaij  B3Mi  (.  on  J  to  return  to  normal  calculator  display. 
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Numerical  solution  for  stiff  first-order  ODE 

Consider  the  ODE:  dy/dt  =  -1  OOy+1  OOt+1 01 ,  subject  to  the  initial  condition 

y{0)=  1. 

Exact  solution 

This  equation  can  be  written  as  dy/dt  +  100  y  =  100  t  +  101,  and  solved 
using  an  integrating  factor,  IF(t)  =  exp(lOOt),  as  follows  (RPN  mode,  with  CAS 
set  to  Exact  mode): 

'(100*t+101)*EXP(100*t)' r  (ENTER)  RISCH 

The  result  is  '(t+1  )*EXP{1 00*t)'. 

Next,  we  add  an  integration  constant,  by  using:  'C         +  j 

Then,  we  divide  by  Fl(x),  by  using:   'EXP(1 00*t)'  (^C+D . 

The  result  is:  '((t+l)*EXP(100*t)+C)/EXP(100*t)',  i.e.,  y(t)  =  1+  t  +C-e^°°'.  Use 
of  the  initial  condition  y(0)  =  1,  results  in  1  =  1  +  0  +  C-e°,  or  C  =  0,  the 
particular  solution  being  y(t)  =  1+t. 

Numerical  solution 

If  we  attempt  a  direct  numerical  solution  of  the  original  equation  dy/dt  =  ■ 
1  OOy+1  OOt+1 01 ,  using  the  calculator's  own  numerical  solver,  we  find  that 
the  calculator  takes  longer  to  produce  a  solution  that  in  the  previous  first-order 
example.  To  check  this  out,  set  your  differential  equation  numerical  solver 
((33  mm  ^  aSSIn)  to:  


SOLVE  V  (T)=F(T,VJ 
f:        -100.*V+100.*t  +  l„, 

Ind<p:t    lnit:0        Final  2  

SoVn--  Y    lnit:l  Final 

T*  I :  .  000 1   itip :  Df  1 1    _  J^iFf 

frm  SOLVE  f*r  final  f*ln  oalm 


iniT+  SOLVE 
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Here  we  are  trying  to  obtain  the  value  of  y(2)  given  y(0)  =  1 .    With  the  Soin: 
Final  field  highlighted,  press  B3EI13.    You  can  check  that  a  solution  takes 
about  6  seconds,  v/hile  in  the  previous  first-order  example  the  solution  was 
almost  instantaneous.  Press  (.  on  J  to  cancel  the  calculation. 


This  is  an  example  of  a  stiff  ordinary  differential  equation.  A  stiff  ODE  is 
one  whose  general  solution  contains  components  that  vary  at  widely  different 
rates  under  the  same  increment  in  the  independent  variable.  In  this  particular 
case,  the  general  solution,  y(t)  =  1+  t  +C-e^°°',  contains  the  components  't' 
and  'C-e^°°",  which  vary  at  very  different  rates,  except  for  the  cases  C=0  or 
C«0  (e.g.,  for  C  =  1,  t  =0.1,  Ce^°°'  =22026). 

The  calculator's  ODE  numerical  solver  allows  for  the  solution  of  stiff  ODEs  by 
selecting  the  option  _stiff  in  the  SOLVE  y' (t)  =  f(t,y)  screen.  With  this 
option  selected  you  need  to  provide  the  values  of  9f/9y  and  5f/5t.  For  the 
case  under  consideration  5f/9y  =  -1 00  and  Sf/9t  =  1 00. 


Enter  those  values  in  the  corresponding  fields  of  the  solve  y'  (T) 
screen: 


F(T,Y) 


SOLVE  V  (T)=F(T,V) 
f  -  '-l...ifi*--  100 

In<Hp:t-     lnit:0  Finj  I  2 

SoVu--  V  Final  HE 

T*l:.0001   St<p:Dflt  ^StiFf 

frill  JOLVE  for  Final  join  ualus 


iniT+  SOLVE 


When  done,  move  the  cursor  to  the  soin:  Final  field  and  press  i!:ffij]|iLlil.  This 
time,  the  solution  in  produced  in  about  1  second.  Press  iLililLay  to  see  the 
solution:  2.9999999999,  i.e.,  3.0. 

Note:  The  option  stiff  is  also  available  for  graphical  solutions  of  differential 
equations. 


Numerical  solution  to  ODEs  with  the  SOLVE/DIFF  menu 

The  SOLVE  soft  menu  is  activated  by  using  74  MENU  in  RPN  mode.  This 
menu  is  presented  in  detail  in  Chapter  6.    One  of  the  sub-menus,  DIFF, 
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contains  functions  for  tfie  numerical  solution  of  ordinary  differential  equations 
for  use  in  programming.  Tfiese  functions  are  described  next  using  RPN  mode 
and  system  flog  1 1 7  set  to  SOFT  menus. 

Tfie  functions  provided  by  tfie  SOLVE/DIFF  menu  are  tfie  following: 


l: 


RRK   RKFST  RRKST  RKFER  RSEER 


Function  RKF 

Tfiis  function  is  used  to  compute  tfie  solution  to  an  initial  value  problem  for  a 
first-order  differential  equation  using  tfie  Runge-Kutta-Fehilbert  4*  -5'^  order 
solution  scheme.  Suppose  that  the  differential  equation  to  be  solved  is  given 
by  dy/dx  =  f(x,y),  with  y  =  0  at  x  =  0,  and  that  you  will  allow  a  convergence 
criteria  8  for  the  solution.  You  can  also  specify  an  increment  in  the 
independent  variable,  Ax,  to  be  used  by  the  function.   To  run  this  function  you 
will  prepare  your  stack  as  follows: 

3:    {V,  y, 'f(x,y)'} 

2:  {8  Ax} 

The  value  in  the  first  stack  level  is  the  value  of  the  independent  variable  where 
you  want  to  find  your  solution,  i.e.,  you  want  to  find,  yfin^i  =  fs(x(inai),  where  f3(x) 
represents  the  solution  to  the  differential  equation.  The  second  stack  level  may 
contain  only  the  value  of  e,  and  the  step  Ax  will  be  token  as  a  small  default 
value.   After  running  function  the  stack  will  show  the  lines: 

2:  {V,  y, 'f(x,y)'} 
1:  8 

The  value  of  the  solution,  yf^^^i,  will  be  available  in  variable  IHniii.  This 
function  is  appropriate  for  programming  since  it  leaves  the  differential 
equation  specifications  and  the  tolerance  in  the  stack  ready  for  a  new  solution. 
Notice  that  the  solution  uses  the  initial  conditions  x  =  0  at  y  =  0.  If,  your 
actual  initial  solutions  are  x  =  Xi^,,  at  y  =  y;„j„  you  can  always  add  these  values 
to  the  solution  provided  by  RKF,  keeping  in  mind  the  following  relationship: 
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RKF  solution 

Actual  solution 

X 

y 

X 

y 

0 

0 

Xinit 

yinit 

'^final 

Vfinal 

'^init  Xfinal 

yinit  ytinal 

The  following  screens  show  the  RPN  stock  before  and  after  applying  function 
RKF  for  the  differential  equation  dy/dx  =  x+y,  e  =  0.001,  Ax  =  0.1 . 


4: 

3: 

Z: 

l: 

2 

4: 
l: 


ix  y  x+yJ 

.001 


RRK   RKF^T  RRK^T  RKFER  R^EER 


After  applying  function  RKF,  variable  IIkIS  contains  the  value  4.3880... 
Function  RRK 

This  function  is  similar  to  the  RKF  function,  except  that  RRK  (Rosenbrock  and 
Runge-Kutta  methods)  requires  as  the  list  in  stack  level  3  for  input  not  only  the 
names  of  the  independent  and  dependent  variables  and  the  function  defining 
the  differential  equation,  but  also  the  expressions  for  the  first  and  second 
derivatives  of  the  expression.  Thus,  the  input  stack  for  this  function  will  look  as 
follows: 

3:    {'x',  y,  'f(x,y)'  'Sf/Sx'  'Sf/Sy'  } 
2:  {e  Ax} 

1  '•  X(inal 

The  value  in  the  first  stock  level  is  the  value  of  the  independent  variable  where 
you  want  to  find  your  solution,  i.e.,  you  want  to  find,  yf;„^]  =  fs(x(;„a|),  where  fs(x) 
represents  the  solution  to  the  differential  equation.  The  second  stack  level  may 
contain  only  the  value  of  e,  and  the  step  Ax  will  be  token  as  a  small  default 
value.  After  running  function  IE333,  the  stock  will  show  the  lines: 

2:     {'x',  y,  'f(x,y)'  '5f/5x'  '5f/vy'  } 

1:  {e  Ax} 

The  value  of  the  solution,  y(|„3i,  will  be  available  in  variable  SESSI. 

This  function  con  be  used  to  solve  so-called  "stiff"  differential  equations. 
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The  following  screen  shots  show  the  RPN  stock  before  and  after  application  of 
function  RRK: 


3: 

t  X 

y  ' -100*y+100*x 

+  101 

^    100    '-I00'  J 

2: 

a    .001    .1  3 

l: 

2 

F  1  RRK 

|RKF£T|RRK£T|RKFER|R£RER 

3: 

2: 

t  X 

y  '-100*y+100*x 

+  101 

^    100    '-100'  > 

l: 

.001 

F  1  RRK 

|RKF£T|RRK£T|RKFER|RfRER 

The  value  stored  in  variable  y  is  3.00000000004. 


Function  RKFSTEP 

This  function  uses  an  input  list  similar  to  that  of  function  RKF,  as  well  as  the 
tolerance  for  the  solution,  and  a  possible  step  Ax,  and  returns  the  some  input 
list,  followed  by  the  tolerance,  and  an  estimate  of  the  next  step  in  the 
independent  variable.  The  function  returns  the  input  list,  the  tolerance,  and 
the  next  step  in  the  independent  variable  that  satisfies  that  tolerance.  Thus, 
the  input  stack  looks  as  follows: 

3:  {V,  y, 'f(x,y)'} 
2:  8 
1:  Ax 


After  running  this  function,  the  stack  will  show  the  lines: 

3:  {V,  y, 'f(x,y)'} 
2:  8 
1 :  (Ax)„3rf 


Thus,  this  function  is  used  to  determine  the  appropriate  size  of  a  time  step  to 
satisfy  the  required  tolerance. 


The  following  screen  shots  show  the  RPN  stack  before  and  after  application  of 


RKFSTEP: 

4: 

3: 

t  X  y  'x*y'  3 

2: 

.001 

l: 

.  1 

RKF£T|RRK£T|RKFER|R£RER 

4: 

3: 

t  X  y  'x*y'  3 

2: 

.001 

l: 

.340493095001 

|RKF£T|RRK£T|RKFER|RfRER 

These  results  indicate  that  {Ax)„e^,  =  0.34049. 
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Function  RRKSTEP 

This  function  uses  an  input  list  similar  to  that  of  function  RRK,  as  well  as  the 
tolerance  for  the  solution,  a  possible  step  Ax,  and  a  number  (LAST)  specifying 
the  last  method  used  in  the  solution  (1 ,  if  RKF  was  used,  or  2,  if  RRK  was 
used).  Function  RRKSTEP  returns  the  same  input  list,  followed  by  the  tolerance, 
an  estimate  of  the  next  step  in  the  independent  variable,  and  the  current 
method  (CURRENT)  used  to  arrive  at  the  next  step.  Thus,  the  input  stack  looks 
as  follows: 

4:  {V,  y, 'f(x,y)'} 
3:  s 
2:  Ax 
1:  LAST 


After  running  this  function,  the  stack  will  show  the  lines: 

4:  {V,  y, 'f(x,y)'} 
3:  s 
2: 
1: 


(Ax),3„ 
CURRENT 


Thus,  this  function  is  used  to  determine  the  appropriate  size  of  a  time  step 
((Ax)peJ  to  satisfy  the  required  tolerance,  and  the  method  used  to  arrive  at  that 
result  (CURRENT). 

The  following  screen  shots  show  the  RPN  stack  before  and  after  application  of 
function  RRKSTEP: 


4: 

t  X  y 

'  -100*y+100*>; 

+  10r 

100    '-I0'  > 

3: 

.0001 

Z: 

.  1 

l: 

1 

RRK   RKF^T  RRK^T  RKFER  R^RER 


3: 
Z: 


t  X  y 
+  10r 


'-100*y+100*X 
100    '-10'  J 

.0001 

5.5SS7S551997E-3 
1. 


RRK   RKF^T  RRK^T  RKFER  RfRER 


These  results  indicate  that  (Ax)^^^,  =  0.00558. 
(CURRENT  =  1)  should  be  used. 


and  that  the  RKF  method 
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Function  RKFERR 

This  function  returns  the  absolute  error  estimate  for  a  given  step  when  solving 
a  problem  as  that  described  for  function  RKF.   The  input  stack  looks  as 
follov/s: 

2:  {V,  y, 'f(x,y)'} 
1:  Ax 

After  running  this  function,  the  stack  v/ill  shov/  the  lines: 

4:    {V,  y, 'f(x,y)'} 

3:  s 

2:  Ay 

1 :  error 
Thus,  this  function  is  used  to  determine  the  increment  in  the  solution.  Ay,  as 
v/ell  as  the  absolute  error  (error). 


The  follov/ing  screen  shots  shov/  the  RPN  stack  before  and  after  application  of 
function  RKFERR: 


?: 

5: 

5: 

4: 

3: 

2: 

t  X  y  'x*y'  J 

l: 

|RKF£T|RRK£T|RKFER|R£eER 

7: 

6: 

5: 

4: 

t  X  y  'x*y'  J 

3: 

Z: 

.327201242271 

l: 

-1.S95374S9701E-6 

RRK  |RKF£T|RRK£T|RKFER|R£RER 

These  result  show  that  Ay  =  0.827...  and  error  = -1 .89... xl  0^ 
Function  RSBERR 

This  function  performs  similarly  to  RKERR  but  with  the  input  elements  listed  for 
function  RRK.  Thus,  the  input  stack  for  this  function  will  look  as  follows: 

2:    {'x',  y,  'f{x,y)'  'Sf/Sx'  'Sf/vy'  } 

1:  Ax 


After  running  the  function,  the  stack  will  show  the  lines: 
4:    {'x',  y,  'f(x,y)'  'di/dx'  '5f/vy'  }: 
3:  E 
2:  Ay 
1 :  error 
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The  following  screen  shots  show  the  RPN  stock  before  and  after  application  of 
function  RSBERR: 


_■  ■ 

4: 
3: 

2: 

a  X 

y  ' -100*y+100*x 

+  101 

^    100    '-I0'  J 

l: 

.  1 

F  1  RRK 

|RKF£T|RRK£T|RKFER|R£eER 

_■  ■ 

4: 

t  X 

y  '-100*y+100*x 

+  101 

^    100    '-10'  J 

3: 

.  1 

2: 

4.  15144617136 

l: 

2.76211716614 

F  1  RRK 

|RKF£T|RRK£T|RKFER|RfRER 

These  results  indicate  that  Ay  =  4.1  514...  and  error  =  2.762...,  for  Dx  =  0.1 . 
Check  that,  if  Dx  is  reduced  to  0.01,  Ay  =  -0.00307...  and  error  = 
0.000547. 


Note:  As  you  execute  the  commands  in  the  DIFF  menu  values  of  x  and  y  will 
be  produced  and  stored  as  variables  in  your  calculator.  The  results  provided 
by  the  functions  in  this  section  will  depend  on  the  current  values  of  x  and  y. 
Therefore,  some  of  the  results  illustrated  above  may  differ  from  what  you  get 
in  your  calculator. 
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Chapter  1 7 

Probability  Applications 

In  this  Chapter  we  provide  examples  of  applications  of  calculator's  functions 
to  probability  distributions. 

The  MTH/PROBABILITY..  sub-menu  -  part  1 

The  MTH/PROBABILITY..  sub-menu  is  accessible  through  the  keystroke 
sequence  CS]<!?5^  •  With  system  flag  117  set  to  CHOOSE  boxes,  the 
following  list  of  MTH  options  is  provided  (see  left-hand  side  figure  below). 
We  have  selected  the  PROBABILITY.,  option  (option  7),  to  show  the  following 
functions  (see  right-hand  side  figure  below): 


HflTH  HEnu 


iD.consTflnTS.. 
ii.fpEciHL  FuncTion;.. 


[cSncLl 


PROEHEILITY  HEHU 

5.RDZ 

fi.UTPC 

1       1       1  jcflncL 

OK 

In  this  section  we  discuss  functions  COMB,  PERM,  I  (factorial),  RAND,  and 
RDZ. 


Factorials,  combinations,  and  permutations 

The  factorial  of  an  integer  n  is  defined  as:  n!  =  n-  (n-1)  •  (n-2)...3-2-1 .  By 
definition,  01  =  1.  Factorials  are  used  in  the  calculation  of  the  number  of 
permutations  and  combinations  of  objects.  For  example,  the  number  of 
permutations  of  r  objects  from  a  set  of  n  distinct  objects  is 

„Pr  =  n(n  - 1)(«  - !)...(«  -  r  + 1)  =        -  r)! 
Also,  the  number  of  combinations  of  n  objects  taken  r  at  a  time  is 


n{n  -  \)(n  -  2)...(n  -  r  + 1)  _  n\ 

r\  r\(n-r)\ 
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To  simplify  notation,  use  P(n,r)  for  permutations,  and  C(n,r)  for  combinations. 
We  can  calculate  combinations,  permutations,  and  factorials  witfi  functions 
COMB,  PERM,  and  !  from  tfie  MTH/PROBABILITY..  sub-menu.  Tfie  operation 
of  tfiose  functions  is  described  next: 

•  COMB{n,r):  Combinations  of  n  items  taken  r  at  a  time 

•  PERM(n,r):  Permutations  of  n  items  taken  r  at  a  time 

•  n!:  Factorial  of  a  positive  integer.  For  a  non-integer,  x!  returns 
r(x-i-l),  wfiere  r(x)  Is  the  Gamma  function  (see  Cfiapter  3).  Tfie 
factorial  symbol  (I)  can  be  entered  also  as  tfie  keystroke  combination 

Example  of  applications  of  tfiese  functions  are  shown  next: 


:COME(10.,6.) 

210. 

:PERM(10.,6.) 

151200. 

:  12.! 

479001600. 

Random  numbers 

The  calculator  provides  a  random  number  generator  that  returns  a  uniformly 
distributed,  random  real  number  between  0  and  1 .  The  generator  is  able  to 
produce  sequences  of  random  numbers.  However,  after  a  certain  number  of 
times  (a  very  large  number  indeed),  the  sequence  tends  to  repeat  itself.  For 
that  reason,  the  random  number  generator  is  more  properly  referred  to  as  a 
pseudo-random  number  generator.  To  generate  a  random  number  with  your 
calculator  use  function  RAND  from  the  MTH/PROBABILITY  sub-menu.  The 
following  screen  shows  a  number  of  random  numbers  produced  using  RAND. 
The  numbers  in  the  left-hand  side  figure  are  produced  with  calling  function 
RAND  without  an  argument.  If  you  place  an  argument  list  in  function  RAND, 
you  get  bock  the  list  of  numbers  plus  an  additional  random  number  attached 
to  it  as  illustrated  in  the  right-hand  side  figure. 
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:RRHD 

.529199353633 

:RflHD 

4.35S21S14444E-2 

:RRHD 

.294922932038 

. 294922932039 

RRHD(5.) 
{5.4. 10S96424443E-2} 
:RRHD(2.,5.) 

{2.  5.  .736370433305} 
RRHD(1.,2.,3.) 
U.  2.  3.  4.07030793137> 


Random  number  generators,  in  general,  operate  by  taking  a  value,  called  the 
"seed"  of  the  generator,  and  performing  some  mathematical  algorithm  on  that 
"seed"  that  generates  a  new  (pseudo)random  number.  If  you  want  to 
generate  a  sequence  of  number  and  be  able  to  repeat  the  same  sequence 
later,  you  can  change  the  "seed"  of  the  generator  by  using  function  RDZ(n), 
where  n  is  the  "seed,"  before  generating  the  sequence.  Random  number 
generators  operate  by  starting  with  a  "seed"  number  that  is  transformed  into 
the  first  random  number  of  the  series.  The  current  number  then  serves  as  the 
"seed"  for  the  next  number  and  so  on.  By  "re-seeding"  the  sequence  with  the 
same  number  you  can  reproduce  the  same  sequence  more  than  once.  For 
example,  try  the  following: 

Use  0.25  as  the  "seed." 
First  random  number  =  0.75285... 
Second  random  number  =  0.51 109... 
Third  random  number=  0.085429.... 


RDZ(0.25) 
RAND()  {ENTg} 
RAND()  {ENTg} 
RANDO 
Re-start  the  sequence: 
RDZ(0.25)  («™) 
RANDO  {ENm} 
RANDQ 
RAND() 


Use  0.25  as  the  "seed." 
First  random  number  =  0.75285... 
Second  random  number  =  0.51 109... 
Third  random  number=  0.085429.... 


To  generate  a  sequence  of  random  numbers  use  function  SEQ.  For  example, 
to  generate  a  list  of  5  random  numbers  you  can  use,  in  ALG  mode: 
i  J  I !  D;  1  f .    In  RPN  mode,  use  the  following  program: 
^  n      1  n  FOR  i  RND  NEXT  n  ^LIST  s-  s- 


Store  it  into  variable  RLST  (Random  LiST),  and  use 
list  of  5  random  numbers. 


CTDSSlSiS  to  produce  a 


Function  RNDM(n,m)  can  be  used  to  generate  a  matrix  of  n  rows  and  m 
columns  whose  elements  are  random  integers  between  -1  and  1  (see  Chapter 
10). 
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Discrete  probability  distributions 

A  random  variable  is  said  to  be  discrete  when  it  can  only  take  a  finite  number 
of  values.  For  example,  the  number  of  rainy  days  in  a  given  location  can  be 
considered  a  discrete  random  variable  because  we  count  them  as  integer 
numbers  only.  Let  X  represent  a  discrete  random  variable,  its  probability  moss 
function  (pmf)  is  represented  by  f(x)  =  P[X=x],  i.e.,  the  probability  that  the 
random  variable  X  takes  the  value  x. 

The  mass  distribution  function  must  satisfy  the  conditions  that 

f(x)  >0,  for  all  X, 

and 

all  X 

A  cumulative  distribution  function  (cdf)  is  defined  as 
F(jc)  =  P[X<x]  =  X/W 

k<x 

Next,  we  will  define  a  number  of  functions  to  calculate  discrete  probability 
distributions.  We  suggest  that  you  create  a  sub-directory,  say, 
HOME\STATS\DFUN  (Discrete  FUNctions)  where  we  will  define  the 
probability  mass  function  and  cumulative  distribution  function  for  the  binomial 
and  Poisson  distributions. 


Binomial  distribution 

The  probability  mass  function  of  the  binomial  distribution  is  given  by 


f(n,p,x)  = 


p'-i\-py-\    x  =  0,\,2,...,n 


where  ("J  =  C(n,x)  is  the  combination  of  n  elements  taken  x  at  a  time.  The 
values  n  and  p  are  the  parameters  of  the  distribution.  The  value  n  represents 
the  number  of  repetitions  of  an  experiment  or  observation  that  can  have  one 
of  two  outcomes,  e.g.,  success  and  failure.  If  the  random  variable  X 
represents  the  number  of  successes  in  the  n  repetitions,  then  p  represents  the 
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probability  of  getting  a  success  in  any  given  repetition.  The  cumulative 
distribution  function  for  the  binomial  distribution  is  given  by 

X 

F{n,p,x)  =  Y^f{n,p,x),    x  =  0,l,2,-,« 
Poisson  distribution 

The  probability  mass  function  of  the  Poisson  distribution  is  given  by 


fiA,x)  = 


,    x  =  0,1,2,. ..,00. 


In  this  expression,  if  the  random  variable  X  represents  the  number  of 
occurrences  of  an  event  or  observation  per  unit  time,  length,  area,  volume, 
etc.,  then  the  parameter  I  represents  the  average  number  of  occurrences  per 
unit  time,  length,  area,  volume,  etc.   The  cumulative  distribution  function  for 
the  Poisson  distribution  is  given  by 

X 

F{A,x)  =  J^f{A,x),   x  =  0,1,2,...,  00 

k=0 

Next,  use  function  DEFINE  ([  <-i  J )  to  define  the  follov/ing  probability  mass 
functions  (pmf)  and  cumulative  distribution  functions  (cdf): 


:=  za::=:M:;i,::.::,pnifhc:n,Ej,k>>;' 

I,''-,  k  ==t:i  ;i  X  ;i  pi'i'iT'p    A, J  X  .•'  .■= 

The  function  names  stand  for: 

•  pmfb:  probability  mass  function  for  the  binomial  distribution 

•  cdfb:  cumulative  distribution  function  for  the  binomial  distribution 

•  pmfp:  probability  mass  function  for  the  Poisson  distribution 

•  cdfp:  cumulative  distribution  function  for  the  Poisson  distribution 


>a,>: 
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Examples  of  calculations  using  these  functions  are  sfiown  next: 


. 129S33720754 
:  cdfbae, .  15,3> 

.950030201121 

:  -^HUMCpmf p(:5,4>> 

. 175467369768 

:  -^HUMCcdf p(:5,4>> 

. 877336S4SS37 

.:dfp  1  PHfp  1  cdfb  1  pHft  1        1  ■ 

P  1  PHfp  1      b  1  pHfb  1  | 

Continuous  probability  distributions 

Tfie  probability  distribution  for  a  continuous  random  variable,  X,  is 
cfiaracterized  by  a  function  f(x)  known  as  the  probability  density  function  (pdf). 
The  pdf  has  the  following  properties:  f(x)  >  0,  for  all  x,  and 

PVX  <  X]  =  Fix)  =  f  J\^)d^. 

•"—CO 

p+CO 

/  {x)dx  =  1 . 

J-GO 

Probabilities  are  calculated  using  the  cumulative  distribution  function  (cdf),  F(x), 
defined  by  P[X  <x\  =  F(x)  =  f  f  (<^)d^  ,  where  P[X<x]  stands  for  "the 

J— 00 

probability  that  the  random  variable  X  is  less  than  the  value  x". 

In  this  section  we  describe  several  continuous  probability  distributions 
including  the  gamma,  exponential,  beta,  and  Weibull  distributions.  These 
distributions  are  described  in  any  statistics  textbook.  Some  of  these 
distributions  make  use  of  a  the  Gamma  function  defined  earlier,  which  is 
calculated  in  the  calculator  by  using  the  factorial  function  as  r(x)  =  (x-1)!,  for 
any  real  number  x. 

The  gamma  distribution 

The  probability  distribution  function  (pdf)  for  the  gamma  distribution  is  given 
by 

m  =  ■       •  exp(-^),/or  x>0,a>0,j3>0; 
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The  corresponding  (cumulative)  distribution  function  (cdf)  would  be  given  by 
an  integral  that  has  no  closed-form  solution. 

The  exponential  distribution 

The  exponential  distribution  is  the  gamma  distribution  with  a  =  1 .  Its  pdf  is 
given  by 

1  X 
f{x)  =  —  -QM-—)Jor  x>0,j3>0, 

while  its  cdf  is  given  by  F(x)  =  1  -  exp(-x/p),  for  x>0,  p  >0. 

The  beta  distribution 

The  pdf  for  the  gamma  distribution  is  given  by 

JXa+^^„-i  .(i_^)^-ij^or  0<x<l,a>0,j3>0 

As  in  the  case  of  the  gamma  distribution,  the  corresponding  cdf  for  the  beta 
distribution  is  also  given  by  an  integral  with  no  closed-form  solution. 

The  Weibull  distribution 

The  pdf  for  the  Weibull  distribution  is  given  by 

f(x)  =  a-  fi-x^'' -expi-a-x^),    for  x>0,a>0,j3  >0 
While  the  corresponding  cdf  is  given  by 

F{x)  =  l-exp(-«  -x^),    for  x  >  0,a  >  Q,P  >  0 
Functions  for  continuous  distributions 

To  define  a  collection  of  functions  corresponding  to  the  gamma,  exponential, 
beta,  and  Weibull  distributions,  first  create  a  sub-directory  called  CFUN 
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(Continuous  FUNctions)  and  define  the  following  functions  (change  to  Approx 
mode): 


Gamma  pdf:      'gpdf(x)  =      (a-l)  *exp  (-x/p)  /  (|3"a*GAMMA(a) ) ' 
Gamma  cdf:  'gcdf{x)  =  J(0,  x,  gpdf  (t)  ,  t)  ' 

Beta  pdf: 

'  Ppdf  (x)=  GAMMA(a+P)  *x'-  (a-1)  *  (1-x)     (P-1)  /  (GAMMA(a)  *GAMMA(P)  )  ' 

Beta  cdf:  '  (3cdf  (x)  =  J(0,x,  Ppdf  (t)  ,t)  ' 

Exponential  pdf:  'epdf(x)  =  exp  (-x/p) /P' 

Exponential  cdf:  'ecdf(x)  =  1  -  EXP(-x/p)' 

Weibull  pdf:  'Wpdf(x)  =  a*p*x'- (p-l)  *exp  (-a*x^p)  ' 
Weibull  cdf:  'Wcdf(x)  =  1  -  exp  (-a*x-^p)  ' 

Use  function  DEFINE  to  define  all  these  functions.  Next,  enter  the  values  of  a 
and  p,  e.g.,  CTIl(iror)(d™)CED(3(^  CID(^  (^C5D(Il(^ 

Finally,  for  the  cdf  for  Gamma  and  Beta  cdf's,  you  need  to  edit  the  program 
definitions  to  add  ^NUM  to  the  programs  produced  by  function  DEFINE.  For 
example,  the  Gamma  cdf,  i.e.,  the  function  gcdf,  should  be  modified  to  read: 

X '^NUM(  1  (0,  X,  gpdf  (t)  ,  t)  )  '  S-  and  stored  back  into  IlilHSI. 
Repeat  the  procedure  for  (Jcdf. 

Unlike  the  discrete  functions  defined  earlier,  the  continuous  functions  defined 
in  this  section  do  not  include  their  parameters  (a  and/or  |3)  in  their  definitions. 
Therefore,  you  don't  need  to  enter  them  in  the  display  to  calculate  the 
functions.  However,  those  parameters  must  be  previously  defined  by  storing 
the  corresponding  values  in  the  variables  a  and  p.  Once  all  functions  and  the 
values  a  and  p  have  been  stored,  you  can  order  the  menu  labels  by  using 
function  ORDER.  The  call  to  the  function  will  be  the  following: 

ORDER({'a','p','gpdf','gcdf','ppdf','pcdf','epdf','ecdf','Wpdf','Wcdf'}) 

Following  this  command  the  menu  labels  will  show  as  follows  (Press  Lwj  to 
move  to  the  second  list.  Press  Inxt)  once  more  to  move  to  the  first  list): 


I 
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Some  examples  of  application  of  thiese  functions,  for  values  of  a  =  2,  |3  =  3, 
are  shown  below.  Notice  tfie  variable  lERR  tfiat  sfiows  up  in  tfie  second 
screen  shot.  This  results  from  a  numerical  integration  for  function  gcdf. 


3>p 


9Pdf  a.2> 

S. 93760061 33 lE-a 


epdf(2.3) 


1.536 
.  1308 
154353006737 


3. 

:  9pdfa 

.2> 

3. 

93760061331E-2 

:  9cdfa 

.2> 

15519355501E-2 

:  ppdfc! 

2> 

1.536 

. 154353006737 

:  ecdf(:2.3> 

. 535440979639 

:  Wpdfa 

.312011699422 

:  Wcdfa 

.364664716763 

fiif  1  «pdf  1 

Continuous  distributions  for  statistical  inference 

In  this  section  we  discuss  four  continuous  probability  distributions  that  are 
commonly  used  for  problems  related  to  statistical  inference.  These 
distributions  are  the  normal  distribution,  the  Student's  t  distribution,  the  Chi- 
square  (x^)  distribution,  and  the  F-distribution.  The  functions  provided  by  the 
calculator  to  evaluate  probabilities  for  these  distributions  are  contained  in  the 
MTH/PROBABILITY  menu  introduced  earlier  in  this  chapter.  The  functions  are 
NDIST,  UTPN,  UTPT,  UTPC,  and  UTPF.  Their  application  is  described  in  the 
following  sections.  To  see  these  functions  activate  the  MTH  menu:  [jjJmth_ 
and  select  the  PROBABILITY  option: 


HHTH  HEnU 

6.  EASE. . 

?.PROEflEILITV.. 

3.FFT.. 

3.  COMPLEX.. 

iD.consTflnTS.. 
ii.spEciHL  FuncTion;..  I 

1       1       1  icflncL 

OK 

PROEAEILITY  HEHU 

6. UTPC 

?.UTPF 

g.UTPn 

S.UTPT 

1  o  n  P  I  s^^^^^^^^ 

1       1       1  jcfincL 

OK 

Normal  distribution  pdf 

The  expression  for  the  normal  distribution  pdf  is: 
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1 


exp[- 


2a' 


where  |a  is  the  mean,  and  ct^  is  the  variance  of  the  distribution.  To  calculate 
the  value  of  f(|a,CT^,x)  for  the  normal  distribution,  use  function  NDIST  with  the 
following  arguments:  the  mean,  \i,  the  variance,  o^,  and,  the  value  x  ,  i.e., 
NDIST(|a,a^,x).  For  example,  check  that  for  a  normal  distribution, 
f(l. 0,0.5,2.0)  =  0.20755374. 

Normal  distribution  cdf 

The  calculator  has  a  function  UTPN  that  calculates  the  upper-tail  normal 
distribution,  i.e.,  UTPN(x)  =  P(X>x)  =  1  ■  P(X<x).  To  obtain  the  value  of  the 
upper-tail  normal  distribution  UTPN  we  need  to  enter  the  following  values:  the 
mean,  (x;  the  variance,  cj^;  and,  the  value  x,  e.g.,  UTPN({(x,cj^,x) 

For  example,  check  that  for  a  normal  distribution,  with  |a  =  1 .0,  ct^  =  0.5, 
UTPN(0.75)  =  0.638163.  Use  UTPN(1 .0,0.5,0.75)  =  0.638163. 

Different  probability  calculations  for  normal  distributions  [X  is  N(h,ct^)]  can  be 
defined  using  the  function  UTPN,  as  follows: 


.     P(X<a)  =  1  ■  UTPN(^,  a2,a) 

.     P(a<X<b)  =  P(X<b)  -  P(X<a)  =  1  -  UTPN(n,  o^b)  -  (1  -  UTPN(n,  c^a)) 

=  UTPN(n,  CT2,a)  -  UTPN(n,  c^b) 
•    P(X>c)  =  UTPN(n,  cj2,c) 

Examples:  Using  \x=  1 .5,  and     =  0.5,  find: 

P(X<1 .0)  =  1  -  P(X>1 .0)  =  1  -  UTPN(1 .5,  0.5,  1 .0)  =  0.239750. 
P(X>2.0)  =  UTPN(1 .5,  0.5,  2.0)  =  0.239750. 

P(l  .0<X<2.0)  =  F(l  .0)  -  F(2.0)  =  UTPN(1 .5,0.5,1 .0)  -  UTPN(1 .5,0.5,2.0) 
=  0.7602499  -  0.2397500  =  0.524998. 
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The  Student-t  distribution 

The  Student-t,  or  simply,  the  t-,  distribution  has  one  parameter  v,  known  as  the 
degrees  of  freedom  of  the  distribution.  The  probability  distribution  function 
(pdf)  is  given  by 

f{t)  =  ^  +  — )   2  ,-oo<r<oo 

r(^).V^  ^ 

where  r{a)  =  (a-1)!  is  the  GAMMA  function  defined  in  Chapter  3. 

The  calculator  provides  for  values  of  the  upper-tail  (cumulative)  distribution 
function  for  the  t-distribution,  function  UTPT,  given  the  parameter  v  and  the 
value  of  t,  i.e.,  UTPT(v,t).  The  definition  of  this  function  is,  therefore, 

J '00  M 
f(t)dt  =  1  -  [  f{t)dt  =  \-P(T<t) 
t  J-OO 

For  example,  UTPT(5,2.5)  =  2.7245. ..E-2.  Other  probability  calculations  for 
the  t-distribution  can  be  defined  using  the  function  UTPT,  as  follows: 

•  P(T<a)  =  1  -  UTPT(v,a) 

•  P(a<T<b)  =  P(T<b)  ■  P(T<a)  =  1  -  UTPT(v,b)  -    (1  -  UTPT(v,a))  = 
UTPT(v,a)  -  UTPT(v,b) 

•  P(T>c)  =  UTPT(v,c) 

Examples:  Given  v  =  1  2,  determine: 

P(T<0.5)  =  1-UTPT(1  2,0.5)  =  0.68694.. 

P(-0.5<T<0.5)  =  UTPT(12,-0.5)-UTPT(  12,0.5)  =  0.3738... 

P(T>  -1 .2)  =  UTPT(1 2,-1 .2)  =  0.8733... 

The  Chi-square  distribution 

The  Chi-square  (x^)  distribution  has  one  parameter  v,  known  as  the  degrees  of 
freedom.  The  probability  distribution  function  (pdf)  is  given  by 
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1 


•x^    -e  ^,v>0,x>0 


2 


The  calculator  provides  for  values  of  the  upper-tail  (cumulative)  distribution 
function  for  the  x^"distribution  using  [UTPC]  given  the  value  of  x  and  the 
parameter  v.  The  definition  of  this  function  is,  therefore, 


To  use  this  function,  we  need  the  degrees  of  freedom,  v,  and  the  value  of  the 
chi-square  variable,  x,  i.e.,  UTPC(v,x).  For  example,  UTPC(5,  2.5)  = 
0.776495... 

Different  probability  calculations  for  the  Chi-squared  distribution  can  be 
defined  using  the  function  UTPC,  as  follov/s: 

.     P(X<a)  =  1  -  UTPC(v,a) 

•  P(a<X<b)  =  P(X<b)  -  P(X<a)  =  1  -  UTPC(v,b)  -    (1  -  UTPC{v,a))  = 
UTPC(v,a)  -  UTPC(v,b) 

•  P(X>c)  =  UTPC(v,c) 

Examples:  Given  v  =  6,  determine: 

P(X<5.32)  =  1-UTPC(6,5.32)  =  0.4965.. 

P(l. 2<X<1 0.5)  =  UTPC(6,1. 2)-UTPC{6, 10.5)  =  0.8717... 

P(X>  20)  =  UTPC(6,20)  =  2.769.. E-3 

The  F  distribution 

The  F  distribution  has  tv^o  parameters  vN  =  numerator  degrees  of  freedom, 
and  vD  =  denominator  degrees  of  freedom.  The  probability  distribution 
function  (pdf)  is  given  by 


UTPC{v,x)  =  rf{x)dx  =  \-['  f{x)dx  =  1  -  P{X  <  x) 

J  t  J  —00 
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The  calculator  provides  for  values  of  tfie  upper-tail  (cumulative)  distribution 
function  for  the  F  distribution,  function  UTPF,  given  the  parameters  vN  and  vD, 
and  the  value  of  F.  The  definition  of  this  function  is,  therefore, 

UTPF{yN,vD,F)=  rf{F)dF  =  \-\'  f{F)dF  =  \-P{'5<F) 

J  t  J  -00 

For  example,  to  calculate  UTPF(10,5,  2.5)  =  0.161834... 

Different  probability  calculations  for  the  F  distribution  can  be  defined  using  the 
function  UTPF,  as  follows: 

•  P(F<a)  =  1  -  UTPF(vN,  vD,a) 

•  P(a<F<b)  =  P(F<b)  ■  P(F<a)  =  1  -UTPF(vN,  vD,b)-  (1  -  UTPF(vN,  vD,a)) 

=  UTPF(vN,  vD,a)  ■  UTPF(vN,  vD,b) 

•  P(F>c)  =  UTPF(vN,  vD,a) 

Example:  Given  vN  =  1 0,  vD  =  5,  find: 

P(F<2)  =  1-UTPF(1 0,5,2)  =  0.7700... 

P(5<F<10)  =  UTPF(1 0,5,5)  -  UTPF(1 0,5,10)  =  3.4693. .E-2 

P(F>5)  =  UTPF(1 0,5,5)  =  4.4808..E-2 

Inverse  cumulative  distribution  functions 

For  a  continuous  random  variable  X  with  cumulative  density  function  (cdf)  F(x) 
=  P(X<x)  =  p,  to  calculate  the  inverse  cumulative  distribution  function  we  need 
to  find  the  value  of  x,  such  that  x  =  F^(p).   This  value  is  relatively  simple  to 
find  for  the  cases  of  the  exponential  and  Weibull  distributions  since  their  cdf's 
have  a  closed  form  expression: 
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•  Exponential,  F(x)  =  1  -exp(-x/p) 

•  Weibull,  F(x)  =  l-exp(-axP) 


(Before  continuing,  make  sure  to  purge  variables  a  and  P).  To  find  the  inverse 
cdf's  for  tfiese  tv/o  distributions  we  need  just  solve  for  x  from  these  expressions, 
i.e.. 


Exponential: 


I  SOLVE 


-X 

6 

P=l-e  ;x' 

x=-[p'LH[-[p-l))l 


Weibull: 


SOLVElp=l-e  "'^  ;x' 


x=e 


For  the  Gamma  and  Beta  distributions  the  expressions  to  solve  v^ill  be  more 

complicated  due  to  the  presence  of  integrals,  i.e., 

„                          1         „_i        ,    z .  , 
•     Gamma,     p  =  z     •  exp(  Wz 

.     Beta,  p=r^^^^^.z"-^.i\-zr^dz 

A  numerical  solution  with  the  numerical  solver  will  not  be  feasible  because  of 
the  integral  sign  involved  in  the  expression.    However,  a  graphical  solution  is 
possible.  Details  on  how  to  find  the  root  of  a  graph  are  presented  in  Chapter 
1  2.  To  ensure  numerical  results,  change  the  CAS  setting  to  Approx.  The 
function  to  plot  for  the  Gamma  distribution  is 

Y(X)  =  I(0,X,z^(a-l)*exp(-z/P)/(P''a*GAMMA(a)),z)-p 


For  the  Beta  distribution,  the  function  to  plot  is 


Y(X)  = 

l(0,X,z'^(a-l  )*(1  -z)'^{p-l  )*GAMMA{a+p)/(GAMMA(a)*GAMMA(p)),z)-p 

To  produce  the  plot,  it  is  necessary  to  store  values  of  a,  p,  and  p,  before 
attempting  the  plot.    For  example,  for  a  =  2,  p  =  3,  and  p  =  0.3,  the  plot  of 
Y{X)  for  the  Gamma  distribution  is  shown  below.  (Please  notice  that,  because 
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of  the  complicated  nature  of  function  Y(X),  it  will  take  some  time  before  the 
graph  is  produced.  Be  patient.) 


-1 — 1 — 1 — 1  >^ — 

V 

-S.5 

-3.1 

S.5 

There  are  two  roots  of  this  function  found  by  using  function  ESEIi  within  the 
plot  environment.  Because  of  the  integral  in  the  equation,  the  root  is 
approximated  and  will  not  be  shown  in  the  plot  screen.  You  will  only  get  the 
message  Constant?  Shown  in  the  screen.  However,  if  you  press  I^nter]  at  this 
point,  the  approximate  root  will  be  listed  in  the  display.  Two  roots  are  shown 
in  the  right-hand  figure  below. 


V 

6.5 

(-1.9,0.) 
(3.3,0.) 


Alternatively,  you  can  use  function  IBEEOHI  1(313)1  to  estimate  the  roots  by 
tracing  the  curve  near  its  intercepts  with  the  x-axis.  Two  estimates  are  shown 
below: 


V 

S.5 

f:S.aHE-3 

V 

-1  1  1  1  ^-_L — 

-S.5 

^3.3 

r:S.?lE-H 

These  estimates  suggest  solutions  x  =  -1 .9  and  x  =  3.3.  You  can  verify  these 
"solutions"  by  evaluating  function  Yl  (X)  for  X  =  -1 .9  and  X  =  3.3,  i.e., 


Yl(-1.9) 
Yl(3.3) 


.009244101213 
.000970724234 
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For  the  normal.  Student's  t,  Chi-square  jy^),  and  F  distributions,  which  are 
represented  by  functions  UTPN,  UTPT,  UPTC,  and  UTPF  in  the  calculator,  the 
inverse  cuff  can  be  found  by  solving  one  of  the  follov/ing  equations: 


Normal, 
Student's  t, 
Chi-square, 
F  distribution: 


p  =  1  -  UTPN(h,ct2,x) 

p  =  1  -  UTPT(v,t) 

p  =  1  -  UTPC(v,x) 

p  =  1  -  UTPF(vN,vD,F) 


Notice  that  the  second  parameter  in  the  UTPN  function  is  o2,  not  cr^, 
representing  the  variance  of  the  distribution.  Also,  the  symbol  v  (the  lower- 
case Greek  letter  no)  is  not  available  in  the  calculator.  You  can  use,  for 
example,  y  (gamma)  instead  of  v.  The  letter  y  is  available  thought  the 
character  set  (CED  owaj  ). 


For  example,  to  obtain  the  value  of  x  for  a  normal  distribution,  with  |a  =  10, 

=  2,  with  p  =  0.25,  store  the  equation  'F'=- 1 -uTPN  t  (x?  ctS?      '  into 
variable  EQ  (figure  in  the  left-hand  side  below).  Then,  launch  the  numerical 
solver,  to  get  the  input  form  in  the  right-hand  side  figure: 


'P=l .  -UTPH(jy  .cr2,x)>EQ 
P=l.-UTPH^iJt,(T2,x> 


£OLVE  ECUHTIOn 

=  l.-UTFH(u,tT2,x> 


Ent«r  ualui  *r  pr«ff  SOLVE 


The  next  step  is  to  enter  the  values  of  |a,  a^,  and  p,  and  solve  for  x: 


SOLVE  ECUHTIOn 

Eg:p=l.-UTPH(iJt,(T2,x> 
p:  .25  n:  JJ 


9.04612... 


Entif  OJlm  Of  pfjff  SOLVE 


vflRS  inro  SOLVE 


This  input  form  can  be  used  to  solve  for  any  of  the  four  variables  involved  in 
the  equation  for  the  normal  distribution. 
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To  facilitate  solution  of  equations  involving  functions  UTPN,  UTPT,  UTPC,  and 
UTPF,  you  may  want  to  create  a  sub-directory  UTPEQ  v/ere  you  will  store  the 
equations  listed  above: 


'p=l .  -UTPH(jy  yCT2,x)>EQH 

P=l.-UTPH<ii,(T£,x) 
'p=l.-UTPTKt)*EQT 

P=l.-UTPT('v,t> 


'p=l.-UTPCKx)>EQC 

P=l.-UTPC<'VjX) 
'P=l .  -UTPF(-vH,-vD,F5*EQF 
P=l.-UTPR'vH,'vD,F> 


Tfius,  at  this  point,  you  will  have  the  four  equations  available  for  solution.  You 
needs  just  load  one  of  the  equations  into  the  EQ  field  in  the  numerical  solver 
and  proceed  with  solving  for  one  of  the  variables.  Examples  of  the  UTPT, 
UTPC,  and  UPTF  are  shown  below: 


£OLVE  ECUHTIOn 
Eq:p=l.-UTPT<'V,t) 


,25 
15 


Enttr  ujlm  or  prgjj  SOLVE 


SOLVE  ECUHTIOn 
Eq:p=l.-UTPC<'V,X) 


,6S 
10 


11.49S77S1S13 


Enttr  00  prgjj  SOLVE 


vflRS I inro  isoLVE 


vflRS  inro  SOLVE 


^^^^SOLVE  E4UflTI0n§ 

Eq:p=l.-UTPF<'vH,'vD,F) 
f-  .25  ^n:  10 

iO-     14  F: 


.650322... 


Zntir  00  Im  *r  fciii  SOLVE 


VHRS  inro  SOLVE 


Notice  that  in  all  the  examples  shown  above,  we  are  working  with  p  =  P(X<x). 
In  many  statistical  inference  problems  we  will  actually  try  to  find  the  value  of  x 
for  which  P(X>x)  =  a.  Furthermore,  for  the  normal  distribution,  we  most  likely 
will  be  working  with  the  standard  normal  distribution  in  which  n  =0,  and  = 
1 .  The  standard  normal  variable  is  typically  referred  to  as  Z,  so  that  the 
problem  to  solve  will  be  P(Z>z)  =  a.  For  these  cases  of  statistical  inference 
problems,  we  could  store  the  following  equations: 
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'o:=UTPH(0.,l.,z)*EQHR 

o:=L(TPHt0.  ,  1.  ,z> 
'o:=UTPT('v,t)>EQTR 

 a=UTFK-v,t> 


'o:=UTPC(-v,x)*EQCR 

o:=UTPCt-v,x> 
'o:=UTPF(-vH/yD,F)>EQFfl 

o:=UTPFt:-vH,-vD,F> 


With  these  four  equations,  whenever  you  launch  the  numerical  solver  you 
have  the  following  choices: 


0 

PROG 

5hI 

PROG 

70l 

PROG 

Sll 

PROG 

Sll 

•  Etc 

PROG 

*ECT 

PROG 

Examples  of  solution  of  equations  EQNA,  EQTA,  EQCA,  and  EQFA  are 
shown  below: 


£OLVE  ECUATIOn^ 

Eg:o:=UTPH(0.  ,  1.  ,z> 
«:  .05 

2- 


1.644S5362695 


Entif  UJlm  Of  pfjff  SOLVE 


vflRS  inro  SOLVE 


SOLVE  ECUATIOn 

Eg:o:=UTPT('V,t> 

«:  .05 

f-  15 


1.75305035569 


Enttf  mlm  or  pfjff  SOLVE 


VflRS  inro  SOLVE 


SOLVE  ECUflTIOn 
Eq:o:=UTPC<'V,x) 

«:  .05 

r-  25 


37.6524341335 


Enttr  ojlm  or  prgjj  SOLVE 


VflRS  inro  SOLVE 


SOLVE  ECUflTIOn 

Eq:c=UTPF<'vH,'vD,F> 
«:  .05  ^n:  5 

iO-  S  F 


3.6S749... 


Enttr  00       or  prgjj  SOLVE 


VflRS  inro  SOLVE 
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Chapter  18 
Statistical  Applications 

In  this  Chapter  we  introduce  statistical  applications  of  the  calculator  including 
statistics  of  a  sample,  frequency  distribution  of  data,  simple  regression, 
confidence  intervals,  and  hypothesis  testing. 

Pre-programmed  statistical  features 

The  calculator  provides  pre-programmed  statistical  features  that  are  accessible 
through  the  keystroke  combination  CS-^  (same  key  as  the  number  I  5  J 
key).  The  statistical  applications  available  in  the  calculator  are: 


2 

3 

Fit  iiti.. 

H 

5 

Hyp^th.  teiti.. 

5 

These  applications  are  presented  in  detail  in  this  Chapter.  First,  hov/ever,  v/e 
demonstrate  how  to  enter  data  for  statistical  analysis. 

Entering  data 

For  the  analysis  of  a  single  set  of  data  (a  sample)  we  can  use  applications 
number  1,  2,  and  4  from  the  list  above.  All  of  these  applications  require  that 
the  data  be  available  as  columns  of  the  matrix  ZDAT.  This  can  be 
accomplished  by  entering  the  data  in  columns  using  the  matrix  writer. 

This  operation  may  become  tedious  for  large  number  of  data  points.  Instead, 
you  may  want  to  enter  the  data  as  a  list  (see  Chapter  8)  and  convert  the  list 
into  a  column  vector  by  using  program  CRMC  (see  Chapter  10). 
Alternatively,  you  can  enter  the  following  program  to  convert  a  list  into  a 
column  vector.  Type  the  program  in  RPN  mode: 

■s  OBJ^  1  2  ^LIST  ^ARRY:^> 
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Store  the  program  in  a  variable  called  LXC.  After  storing  this  program  in  RPN 
mode  you  can  also  use  it  in  ALG  mode. 

To  store  a  column  vector  into  variable  2DAT  use  function  STOE,  available 
through  the  catalog  (CB-«i; ),  e.g.,  STOS  {ANS(l))  in  ALG  mode. 

Example  1  -  Using  the  program  LXC,  defined  above,  create  a  column  vector 
using  the  follov/ing  data:  2.1  1.2  3.1  4.5  2.3  1.1  2.3  1.5  1.6 
2.2    1.2  2.5. 

In  RPG  mode,  type  in  the  data  in  a  list: 

{2.1   1.2   3.1  4.5   2.3    1.1  2.3    1.5    1.6   2.2    1.2   2.5  }(«s)™i 
Use  function  STOS  to  store  the  data  into  SDAT. 
Calculating  single-variable  statistics 

Assuming  that  the  single  data  set  was  stored  as  a  column  vector  in  variable 
SDAT.  To  access  the  different  STAT  programs,  press  [  r>  jJW  .  Press  Blid  to 
select  1.  Single-var..  There  will  be  available  to  you  an  input  form  labeled 
SINGLE-VARIABLE  STATISTICS,  v/ith  the  data  currently  in  your  EDAT  variable 
listed  in  the  form  as  a  vector.  Since  you  only  have  one  column,  the  field  Col; 
should  have  the  value  1  in  front  of  it.  The  Type  field  determines  v/hether  you 
are  working  with  a  sample  or  a  population,  the  default  setting  is  Sample. 
Move  the  cursor  to  the  horizontal  line  preceding  the  fields  Mean,  Std  Dev, 
Variance,  Total,  Maximum,  Minimum,  pressing  the  !>^SIIII  soft  menu  key  to 
select  those  measures  that  you  want  as  output  of  this  program.  When  ready, 
press  The  selected  values  will  be  listed,  appropriately  labeled,  in  the 

screen  of  your  calculator. 

Example  1  -  For  the  data  stored  in  the  previous  example,  the  single-variable 
statistics  results  are  the  following: 

Mean:  2.133,  Std  Dev:  0.964,  Variance:  0.929 
Total:  25.6,  Maximum:  4.5,  Minimum:  1.1 
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Definitions 

The  definitions  used  for  thiese  quantities  ore  tfie  following: 


Suppose  that  you  have  a  number  data  points  x^,  X2,  X3,  representing 
different  measurements  of  the  same  discrete  or  continuous  variable  x.  The  set 
of  all  possible  values  of  the  quantity  x  is  referred  to  as  the  population  of  x.  A 
finite  population  v/ill  have  only  a  fixed  number  of  elements  x,.  If  the  quantity  x 
represents  the  measurement  of  a  continuous  quantity,  and  since,  in  theory, 
such  a  quantity  can  take  an  infinite  number  of  values,  the  population  of  x  in 
this  case  is  infinite.  If  you  select  a  sub-set  of  a  population,  represented  by 
the  n  data  values  {x,,  X2,  x„},  we  say  you  have  selected  a  sample  of  values 
of  X. 

Samples  are  characterized  by  a  number  of  measures  or  statistics.  There  are 
measures  of  central  tendency,  such  as  the  mean,  median,  and  mode,  and 
measures  of  spreading,  such  as  the  range,  variance,  and  standard  deviation. 

Measures  of  antral  tendency 

The  mean  (or  arithmetic  mean)  of  the  sample,  x,  is  defined  as  the  average 
value  of  the  sample  elements. 


The  value  labeled  Total  obtained  above  represents  the  summation  of  the 
values  of  x,  or  Sx,  =  n-  x.  This  is  the  value  provided  by  the  calculator  under 

the  heading  Mean.  Other  mean  values  used  in  certain  applications  are  the 
geometric  mean,  Xg,  or  the  harmonic  mean,  X[„  defined  as: 

-ni  : —  J_-vJ_ 

Examples  of  calculation  of  these  measures,  using  lists,  are  available  in 
Chapter  8. 

The  median  is  the  value  that  splits  the  data  set  in  the  middle  when  the 

elements  are  placed  in  increasing  order.  If  you  have  an  odd  number,  n,  of 
ordered  elements,  the  median  of  this  sample  is  the  value  located  in  position 
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(n+l)/2.  If  you  have  an  even  number,  n,  of  elements,  the  median  is  the 
average  of  the  elements  located  in  positions  n/2  and  (n+l)/2.  Although  the 
pre-programmed  statistical  features  of  the  calculator  do  not  include  the 
calculation  of  the  median,  it  is  very  easily  to  v/rite  a  program  to  calculate  such 
quantity  by  working  with  lists.  For  example,  if  you  want  to  use  the  data  in 
EDAT  to  find  the  median,  type  the  following  program  in  RPN  mode  (see 
Chapter  21  for  more  information  on  programming  in  User  RPL  language).: 

^  nC  ■*:  RCLE  DUP  SIZE  2  GET  IF  1  >  THEN  nC  COL-  SWAP  DROP 
OBJ^  1  +  ^ARRY  END  OBJ^  OBJ^  DROP  DROP  DUP  ^  n  *:  ^LIST  SORT 
IF  'n  MOD  2  ==  0'  THEN  DUP  'n/2'  EVAL  GET  SWAP  '(n+1  )/2'  EVAL  GET  + 
2  /  ELSE  '{n+l)/2'  EVAL  GET  END  "Median"  ^TAG  JJ-  :^>  s- 

Store  this  program  under  the  name  MED.  An  example  of  application  of  this 
program  is  shown  next. 

Example  2  -  To  run  the  program,  first  you  need  to  prepare  your  EDAT  matrix. 
Then,  enter  the  number  of  the  column  in  SDAT  whose  median  you  want  to  find, 
and  press  lEIiiB.    For  the  data  currently  in  SDAT  (entered  in  an  earlier 
example),  use  program  MED  to  show  that  Median :  2.15. 

The  mode  of  a  sample  is  better  determined  from  histograms,  therefore,  we 
leave  its  definition  for  a  later  section. 

/treasures  of  spread 

1  " 

The  variance  (Var)  of  the  sample  is  defined  as      =  ~  ^)  ■ 

The  standard  deviation  (St  Dev)  of  the  sample  is  just  the  square  root  of  the 
variance,  i.e.,  s^. 

The  range  of  the  sample  is  the  difference  between  the  maximum  and  minimum 
values  of  the  sample.  Since  the  calculator,  through  the  pre-programmed 
statistical  functions  provides  the  maximum  and  minimum  values  of  the  sample, 
you  can  easily  calculate  the  range. 
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Coefficient  of  variation 

The  coefficient  of  variation  of  a  sample  combines  the  mean,  a  measure  of 
central  tendency,  with  the  standard  deviation,  a  measure  of  spreading,  and  is 
defined,  as  a  percentage,  by:     =  (s^  x)100. 

Sample  vs.  population 

The  pre-programmed  functions  for  single-variable  statistics  used  above  can  be 
applied  to  a  finite  population  by  selecting  the  Type:  Population  in  the 
SINGLE-VARIABLE  STATISTICS  Screen.  The  main  difference  is  in  the  values 
of  the  variance  and  standard  deviation  v^hich  are  calculated  using  n  in  the 
denominator  of  the  variance,  rather  than  (n-1 ). 

Example  3  ~  If  you  were  to  repeat  the  exercise  in  Example  1  of  this  section, 
using  Population  rather  than  Sample  as  the  Type,  you  will  get  the  same 
values  for  the  mean,  total,  maximum,  and  minimum.  The  variance  and 
standard  deviation,  however,  will  be  given  by:  Variance:  0.852,  Std  Dev: 
0.923. 


Obtaining  frequency  distributions 

The  application  2.  Frequencies.,  in  the  STAT  menu  can  be  used  to  obtain 
frequency  distributions  for  a  set  of  data.  Again,  the  data  must  be  present  in 
the  form  of  a  column  vector  stored  in  variable  SDAT.  To  get  started,  press 
[  i->  J  STAT  v^y  SEI3SI.  The  resulting  input  form  contains  the  following  fields: 


ZDAT:  the  matrix  containing  the  data  of  interest. 

Col:  the  column  of  SDAT  that  is  under  scrutiny. 

X-Min:  the  minimum  class  boundary  (default  =  -6.5). 

Bin  Count:  the  number  of  classes(default  =  1  3). 

Bin  Width:  the  uniform  width  of  each  class  (default  =  1 ). 


Definitions 

To  understand  the  meaning  of  these  parameters  we  present  the  following 
definitions:  Given  a  set  of  n  data  values:  {x,,  X2,  x^}  listed  in  no  particular 
order,  it  is  often  required  to  group  these  data  into  a  series  of  classes  by 
counting  the  frequency  or  number  of  values  corresponding  to  each  class. 
(Note:  the  calculators  refers  to  classes  as  bins). 
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Suppose  that  the  classes,  or  bins,  will  be  selected  by  dividing  the  interval  (xt,ot, 
x,op),  into  k  =  Bin  Count  classes  by  selecting  a  number  of  class  boundaries, 
i.e.,  {xBi,  xBj,  xB^+,},  so  that  class  number  1  is  limited  by  xB^-xBj,  class 
number  2  by  XB2-  XB3,  and  so  on.  The  last  class,  class  number  k,  v/ill  be 
limited  by  xB^,■  xB|,+i. 

The  value  of  x  corresponding  to  the  middle  of  each  class  is  known  as  the  class 
mark,  and  is  defined  as  xM|  =  (xB|  +  xB  i+i)/2,  for  i  =  1,  2,  k. 

If  the  classes  are  chosen  such  that  the  class  size  is  the  same,  then  we  can 
define  the  class  size  as  the  value  Bin  Width  =  Ax  =  (x^^^  -  x„|„)  /  k, 

and  the  class  boundaries  can  be  calculated  as  xB,  =  x^^,  +  (i  -  1 )  *  Ax. 

Any  data  point,  Xj,  j  =  1,  2,      n,  belongs  to  the  i-th  class,  if  xB|<  Xj  <  xB  1+1 

The  application  2.  Frequencies.,  in  the  STAT  menu  will  perform  this  frequency 
count,  and  will  keep  track  of  those  values  that  may  be  below  the  minimum 
and  above  the  maximum  class  boundaries  (i.e.,  the  outliers). 

Example  1  -  In  order  to  better  illustrate  obtaining  frequency  distributions,  we 
want  to  generate  a  relatively  large  data  set,  say  200  points,  by  using  the 
following: 

•  First,  seed  the  random  number  generator  using:  R[yZ''£5)  in  ALG  mode, 
or  25  [fwresj  RDZ  in  RPN  mode  (see  Chapter  17). 

•  Type  in  the  following  program  in  RPN  mode: 

■s  ^  n  K  1  n  FOR  j  RAND  100  *  2  RND  NEXT  n  ^LIST  s-  s- 
and  save  it  under  the  name  RDLIST  (RanDom  number  LIST  generator). 

•  Generate  the  list  of  200  number  by  using  RDLIST(200)  in  ALG  mode,  or 
288  jcNTER]  IMsMm  in  RPN  mode. 

•  Use  program  LXC  (see  above)  to  convert  the  list  thus  generated  into  a 
column  vector. 

•  Store  the  column  vector  into  EDAT,  by  using  function  STOE. 
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•  obtain  single-variable  information  using:  l^i^l  ™t  "-"T:!"!:.  Use  Sample  for 
the  Type  of  data  set,  and  select  all  options  as  results.  Tfie  results  for  tfiis 
example  were: 

Mean:  51.0406,  Std  Dev:  .29.5893...,  Variance:  875.529... 
Total:  10208.12,  Maximum:  99.35,  Minimum:  0.13 

Tfiis  information  indicates  that  our  data  ranges  from  values  close  to  zero  to 
values  close  to  100.  Working  with  whole  numbers,  we  can  select  the  range 
of  variation  of  the  data  as  (0,1 00).   To  produce  a  frequency  distribution  we 
will  use  the  interval  (10,90)  dividing  it  into  8  bins  of  width  10  each. 

•  Select  the  program  2.  Frequencies.,  by  using  C3^5^^^  saillii.  The 
data  is  already  loaded  in  SDAT,  and  the  option  Col  should  hold  the  value 
1  since  we  have  only  one  column  in  SDAT. 

•  Change  X-Min  to  1 0,  Bin  Count  to  8,  and  Bin  Width  to  1 0,  then  press 

ll!B]i?ITIIB]K 

mmm. 

Using  the  RPN  mode,  the  results  are  shown  in  the  stack  as  a  column  vector  in 
stack  level  2,  and  a  row  vector  of  two  components  in  stack  level  1 .  The 
vector  in  stack  level  1  is  the  number  of  outliers  outside  of  the  interval  where 
the  frequency  count  was  performed.  For  this  case,  I  get  the  values  [  25.  22.] 
indicating  that  there  are,  in  my  SDAT  vector,  25  values  smaller  than  10  and 
22  larger  than  90. 

•  Press  L    J  to  drop  the  vector  of  outliers  from  the  stack.  The  remaining 
result  is  the  frequency  count  of  data.  This  can  be  translated  into  a  table 
as  shown  below. 

This  table  was  prepared  from  the  information  we  provided  to  generate  the 
frequency  distribution,  although  the  only  column  returned  by  the  calculator  is 
the  Frequency  column  (fj).  The  class  numbers,  and  class  boundaries  are  easy 
to  calculate  for  uniform-size  classes  (or  bins),  and  the  class  mark  is  just  the 
average  of  the  class  boundaries  for  each  class.  Finally,  the  cumulative 
frequency  is  obtained  by  adding  to  each  value  in  the  last  column,  except  the 
first,  the  frequency  in  the  next  row,  and  replacing  the  result  in  the  last  column 
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of  the  next  row.  Thus,  for  the  second  class,  the  cumulative  frequency  is 
18+15  =  33,  while  for  class  number  3,  the  cumulative  frequency  is  33  +  16  = 
49,  and  so  on.  The  cumulative  frequency  represents  the  frequency  of  those 
numbers  that  are  smaller  than  or  equal  to  the  upper  boundary  of  any  given 
class. 


Class 

Class 

Bound. 

Class 

Frequency 

Cumulative 

No. 

mark. 

i 

XB; 

XB 

Xm; 

fi 

frequency 

<XB, 

outlier 

below 
range 

25 

1 

10 

20 

15 

18 

18 

2 

20 

30 

25 

14 

32 

3 

30 

40 

35 

17 

49 

4 

40 

50 

45 

17 

66 

5 

50 

60 

55 

22 

88 

6 

60 

70 

65 

22 

110 

7 

70 

80 

75 

24 

134 

k=8 

80 

90 

85 

19 

153 

>XB, 

outliers 

above 

22 

—  -■  '  ' — " — 1 

range 

Given  the  (column)  vector  of  frequencies  generated  by  the  calculator,  you  can 
obtain  a  cumulative  frequency  vector  by  using  the  following  program  in  RPN 
mode: 

■^K  DUP  SIZE  1  GET  ^  freq  k  s  {k  1}  0  CON  ^  cfreq  ■^^  'freq(1,1)'  EVAL 
'cfreq(l,l)'  STO  2  k  FOR  j  'cfreq(j-l,l)  +freq(j,l)'  EVAL  'cfreq  {j,l)'  STO 
NEXT  cfreq  s> 

Save  it  under  the  name  CFREQ.  Use  this  program  to  generate  the  list  of 
cumulative  frequencies  (press  EiOHili  with  the  column  vector  of  frequencies  in 
the  stack).  The  result,  for  this  example,  is  a  column  vector  representing  the  last 
column  of  the  table  above. 
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Histograms 

A  histogram  is  a  bar  plot  showing  the  frequency  count  as  the  height  of  the 
bars  while  the  class  boundaries  shown  the  base  of  the  bars.  If  you  have  your 
raw  data  (i.e.,  the  original  data  before  the  frequency  count  is  made)  in  the 
variable  2DAT,  you  can  select  Histogram  as  your  graph  type  and  provide 
information  regarding  the  initial  value  of  x,  the  number  of  bins,  and  the  bin 
width,  to  generate  the  histogram.  Alternatively,  you  can  generate  the  column 
vector  containing  the  frequency  count,  as  performed  in  the  example  above, 
store  this  vector  into  EDAT,  and  select  Barpiot  as  your  graph  type.  In  the 
next  example,  we  show  you  how  to  use  the  first  method  to  generate  a 
histogram. 

Example  1  -  Using  the  200  data  points  generated  in  the  example  above 
(stored  as  a  column  vector  in  EDAT),  generate  a  histogram  plot  of  the  data 
using  X-Min  =  10,  Bin  Count  =  16,  and  Bin  Width  =  5. 

•  First,  press  (Jnjjra??.  (simultaneously,  if  in  RPN  mode)  to  enter  the  PLOT 
SETUP  screen.  Within  this  screen,  change  Type:  to  Histogram,  and  check 
that  the  option  Col:  1  is  selected.  Then,  press  (j«<TjllillSI]:lilli. 

•  Next,  press  [JiJ  jw_  (simultaneously,  if  in  RPN  mode)  to  enter  the  PLOT 
WINDOW  -  HISTOGRAM  screen.  Within  that  screen  modify  the 
information  to  H-View:  1 0   90,  V-View:  0     1 5,  Bar  Width:  5. 

•  Press  ILsEliEljil  yjiiiiiii  to  generate  the  following  histogram: 


.  Press  muss  to  return  to  the  previous  screen.  Change  the  V-view  and  Bar 
Width  once  more,  now  to  read  V-View:  0  30,  Bar  Width:  10.  The  new 
histogram,  based  on  the  same  data  set,  now  looks  like  this: 
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A  plot  of  frequency  count,  fj,  vs.  class  marks,  xM;,  is  known  as  a  frequency 
polygon.  A  plot  of  the  cumulative  frequency  vs.  the  upper  boundaries  is 
known  as  a  cumulative  frequency  ogive.  You  can  produce  scatterplots  that 
simulate  these  two  plots  by  entering  the  proper  data  in  columns  1  and  2  of  a 
new  EDAT  matrix  and  changing  the  Type:  to  scatter  in  the  PLOT  SETUP 
window. 

Fitting  data  to  a  function  y  =  f(x) 

The  program  3.  Fit  data..,  available  as  option  number  3  in  the  STAT  menu, 
can  be  used  to  fit  linear,  logarithmic,  exponential,  and  power  functions  to 
data  sets  (x,y),  stored  in  columns  of  the  EDAT  matrix.  In  order  for  this 
program  to  be  effective,  you  need  to  have  at  least  two  columns  in  your  SDAT 
variable. 


Example  1  -  Fit  a  linear  relationship  to  the  data  shown  in  the  table  below: 


X 

0 

1 

2 

3 

4 

5 

y 

0.5 

2.3 

3.6 

6.7 

7.2 

11 

First,  enter  the  two  rows  of  data  into  column  in  the  variable  SDAT  by 
using  the  matrix  writer,  and  function  STOS. 

To  access  the  program  3.  Fit  data..,  use  the  following  keystrokes: 
CED-?5S;^^  113311  The  input  form  will  show  the  current  ZDAT, 
already  loaded.  If  needed,  change  your  set  up  screen  to  the  following 
parameters  for  a  linear  fitting: 


FIT  DflTflS 


[[  0.   .5  ]  C  1.  ... 


K-C*l:    1  Y-C*l:2 

M*d<i:  Linear  Fit 
Ent«r  ftatiftica  I  data 


EDIT  CHOO£  PRED  CHnCL  OK 
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•  To  obtain  the  data  fitting  press  lillLllil.  The  output  from  this  program, 
shown  below  for  our  particular  data  set,  consists  of  the  following  three 
lines  in  RPN  mode: 

3:  '0.195238095238  +  2.00857142857*X' 
2:  Correlation:  0.983781424465 
1 :  Covariance:  7.03 

Level  3  shows  the  form  of  the  equation.  In  this  case,  y  =  0.06924  +  0.00383 
X.  Level  2  shows  the  sample  correlation  coefficient,  and  level  1  shows  the 
covariance  of  x-y. 

Definitions 

For  a  sample  of  data  points  (x,y),  we  define  the  sample  covariance  as 

1  " 
n  —  i  i=i 

The  sample  correlation  coefficient  for  x,y  is  defined  as 


Where  s„  Sy  are  the  standard  deviations  of  x  and  y,  respectively,  i.e. 

n-l  i=i  «-l,=i 

The  values  s,<y  and  r^y  are  the  "Covariance"  and  "Correlation,"  respectively, 
obtained  by  using  the  "Fit  data"  feature  of  the  calculator. 

Linearized  relationships 

Many  curvilinear  relationships  "straighten  out"  to  a  linear  form.  For  example, 
the  different  models  for  data  fitting  provided  by  the  calculator  can  be 
linearized  as  described  in  the  table  below. 
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Type  of 
Fitting 

Actual 
Model 

Linearized 
Model 

Indep. 
variable 

Depend. 
Variable 

Covar. 

Linear 

y  =  a  +  bx 

[same] 

X 

y 

Sxy 

Log. 

y  =  a  +  b  ln(x) 

[same] 

ln(x) 

y 

S|n(x),y 

Exp. 

y  =  a  e""* 

ln(y)  =  ln(a)  +  bx 

X 

ln(y) 

Sx,ln(y) 

Power 

y  =  a  x'' 

ln(y)  =  ln(a)  +  b ln(x) 

ln(x) 

ln(y) 

S|n(x),ln(y) 

The  sample  covariance  of  ^,r\  is  given  by       =  Z_,{4i 

n-\ 

Also,  we  define  tfie  sample  variances  of  ^  and  ri,  respectively,  as 

Tfie  sample  correlation  coefficient  r^^  is  r,  =  

Tfie  general  form  of  tfie  regression  equation  is   t]  =  A  +  B^. 
Best  data  fitting 

Tfie  calculator  can  determine  v/fiicfi  one  of  its  linear  or  linearized  relationsfiip 
offers  the  best  fitting  for  a  set  of  (x,y)  data  points.  We  will  illustrate  the  use  of 
this  feature  with  an  example.  Suppose  you  want  to  find  which  one  of  the  data 
fitting  functions  provides  the  best  fit  for  the  following  data: 


x 

0.2 

0.5 

1 

1.5 

2 

4 

5 

10 

y 

3.16 

2.73 

2.12 

1.65 

1.29 

0.47 

0.29 

0.01 

First,  enter  the  data  as  a  matrix,  either  by  using  the  Matrix  Writer  and 
entering  the  data,  or  by  entering  two  lists  of  data  corresponding  to  x  and  y 
and  using 
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the  program  CRMC  developed  in  Chapter  1 0.  Next,  save  this  matrix  into  the 
statistical  matrix  2DAT,  by  using  function  STOS. 


Finally,  launch  the  data  fit  application  by  using:  (j^ v^/' EEBI  .  The 
display  shows  the  current  ZDAT,  already  loaded.  Change  your  set  up  screen 
to  the  follov/ing  parameters  if  needed: 


[[ 
1 


5  FIT  DflTfl? 

.2  3. 16 


]  [ 


Best  Fit 


Press  SSSSS,  to  get: 


1:  '3.99504833324*EXP(-.579206831203*X)' 
2:  Correlation:  -0.996624999526 
3:  Covariance:  -6.233506661 24 


The  best  fit  for  the  data  is,  therefore,  y  =  3.995  e°^^\ 
Obtaining  additional  summary  statistics 

The  application  4.  Summary  stats.,  in  the  STAT  menu  can  be  useful  in  some 
calculations  for  sample  statistics.  To  get  started,  press  (.  J  stat  once  more, 
move  to  the  fourth  option  using  the  dov/n-arrov/  key  Vj/",  and  press  SESIS. 
The  resulting  input  form  contains  the  follov/ing  fields: 


SDAT;  the  matrix  containing  the  data  of  interest. 

X-Col,  Y-Col!      these  options  apply  only  v/hen  you  have  more  than  two 

columns  in  the  matrix  SDAT.    By  default,  the  x  column  is 

column  1,  and  the  y  column  is  column  2. 
_sx_  EY...:       summary  statistics  that  you  can  choose  as  results  of  this 

program  by  checking  the  appropriate  field  using  [■/CHK] 

when  that  field  is  selected. 

Many  of  these  summary  statistics  are  used  to  calculate  statistics  of  two 
variables  (x,y)  that  may  be  related  by  a  function  y  =  f(x).  Therefore,  this 
program  can  be  thought  off  as  a  companion  to  program  3.  Fit  data.. 

Example  1  -  For  the  x-y  data  currently  in  EDAT,  obtain  all  the  summary 
statistics. 
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•  To  access  the  summary  stats...  option,  use:  GlD  KIM 

•  Select  the  column  numbers  corresponding  to  the  x-  and  y-data,  i.e.,  X-Col: 
1,  and  Y-Col:  2. 

•  Using  the  IKS]]:li  key  select  all  the  options  for  outputs,  i.e.,  _SX,  _ZY,  etc. 

•  Press         to  obtain  the  following  results: 

EX:  24.2,  SY:  1 1.72,  SX2:  148.54,  SY2:  26.6246,  SXY:  12.602,  NS:8 


Note:  There  are  two  other  applications  under  the  STAT  menu,  namely,  5. 
Hypth.  tests.,  and  6.  Conf.  Interval..  These  two  applications  will  be  discussed 
later  in  the  chapter. 


Calculation  of  percentiles 

Percentiles  are  measures  that  divide  a  data  set  into  100  parts.  The  basic 
procedure  to  calculate  the  lOO  p-th  Percentile  (0  <  p  <  1)  in  a  sample  of  size 
n  is  as  follows: 

1 .  Order  the  n  observations  from  smallest  to  largest. 

2.  Determine  the  product  n  p 

A.  If  n  p  is  not  on  integer,  round  it  up  to  the  next  integer  and  find  the 
corresponding  ordered  value. 

B.  If  n-p  is  an  integer,  say  k,  calculate  the  mean  of  the  k-th  and  (k-1)  th 
ordered  observations. 


Note:  Integer  rounding  rule,  for  a  non-integer  x.yz...,  if  y  >  5,  round  up  to 
x+1;  if  y  <  5,  round  up  to  x. 


This  algorithm  can  be  implemented  in  the  following  program  typed  in  RPN 
mode  (See  Chapter  21  for  programming  information): 

«  SORT  DUP  SIZE  ^  p  X  n  *:  n  p  *  ^  k  *:  IF  k  CEIL  k  FLOOR  -  NOT  THEN  X 
k  GET  X  k  1  +  GET  +  2  /  ELSE  k  0  RND  X  SWAP  GET  END  s-  s> 
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which  we'll  store  in  variable  %TILE  (percent-tile).  This  program  requires  as 
input  a  value  p  within  0  and  1,  representing  the  lOOp  percentile,  and  a  list 
of  values.  The  program  returns  the  lOOp  percentile  of  the  list. 

Example  1  -  Determine  the  37%  percentile  of  the  list  {21  01  351  2367 

9}.  In  RPN  mode,  enter  0.27  («^{21013512367  9}S 

In  ALG  mode,  enter  %TILE(0.27,{2, 1,0, 1,3,5, 1,2,3,6,7, 9}.  The  result  is  1. 

The  STAT  soft  menu 

All  the  pre-programmed  statistical  functions  described  above  are  accessible 
through  a  STAT  soft  menu.  The  STAT  soft  menu  can  be  accessed  by  using,  in 
RPN  mode,  the  command:  96  MENU 

You  can  create  your  own  program,  say  HHlu,  to  activate  the  STAT  soft  menu 
directly.  The  contents  of  this  program  are  simply:  s  96  MENU 

The  STAT  soft  menu  contains  the  following  functions: 


dMTT E phrT  1  vSrT F- lotT  fitTsums 


Pressing  the  key  corresponding  to  any  of  these  menus  provides  access  to 
different  functions  as  described  below. 

The  DATA  sub-menu 

The  DATA  sub-menu  contains  functions  used  to  manipulate  the  statistics  matrix 
2DATA: 


The  operation  of  these  functions  is  as  follows: 

1,+  :  add  row  in  level  1  to  bottom  of  SDATA  matrix. 

S-  :  removes  last  row  in  SDATA  matrix  and  places  it  in  level  of  1  of  the  stack. 

The  modified  ZDATA  matrix  remains  in  memory. 
CLE  :  erases  current  EDATA  matrix. 
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ZDAT:  places  contents  of  current  SDATA  matrix  in  level  1  of  the  stack. 
[  <n  J  SPAT:  stores  matrix  in  level  1  of  stack  into  SDATA  matrix. 

The  EPAR  sub-menu 

Tfie  EPAR  sub-menu  contains  functions  used  to  modify  statistical  parameters. 
Tfie  parameters  sfiown  correspond  to  tfie  last  example  of  data  fitting. 


Intercept:  3.99504S333 
Slope:  -.579206331203 
Model:  EXPFIT 


XCOL  I  YCOL  I  HODL  |  EPHR  |RE£ET|  inFO 


Thie  parameters  sfiown  in  tfie  display  are: 

Xcol:  indicates  column  of  2DATA  representing  x  (Default:  1) 
Ycol:  indicates  column  of  EDATA  representing  y  (Default:  2) 
Intercept:  shows  intercept  of  most  recent  data  fitting  ((Default:  0) 
Slope:  shows  slope  of  most  recent  data  fitting  (Default:  0) 
Model:  shows  current  data  fit  model  (Default:  UNFIT) 

The  functions  listed  in  the  soft  menu  keys  operate  as  follows: 

XCOL:  entered  as  n  EI1lI]I,  changes  Xcol  to  n. 

YCOL:  entered  as  n  MaM,  changes  Ycol  to  n. 

SPAR:   shows  statistical  parameters. 

RESET:  reset  parameters  to  default  values 

INFO:  shows  statistical  parameters 

The  MODL  sub-menu  within  EPAR 

This  sub-menu  contains  functions  that  let  you  change  the  data-fitting  model  to 
LINFIT,  LOGFIT,  EXPFIT,  PWRFIT  or  BESTFIT  by  pressing  the  appropriate  button. 

The  1VAR  sub  menu 

The  1 VAR  sub  menu  contains  functions  that  are  used  to  calculate  statistics  of 
columns  in  the  EDATA  matrix. 
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l: 

u  ^ 

TOT  1  HEHn  1  f  DEV  |  HHXE  |  HIHE  |  EIH^ 

The  functions  available  are  the  following; 


TOT:  show  sum  of  each  column  in  SDATA  matrix. 

MEAN:  shows  average  of  each  column  in  EDATA  matrix. 

SDEV:  shows  standard  deviation  of  each  column  in  EDATA  matrix. 

MAXS:  shows  maximum  value  of  each  column  in  EDATA  matrix. 

MINE:  shows  average  of  each  column  in  EDATA  matrix. 

BINS:  used  as  X5,  Ax,  n  [BINS],  provides  frequency  distribution  for  data  in 

Xcol  column  in  EDATA  matrix  with  the  frequency  bins  defined  as 

[x5,Xs+Ax],  [x5,Xs+2Ax],...,  [Xs,Xs+nAx]. 
VAR:  shows  variance  of  each  column  in  EDATA  matrix. 
PSDEV:  shows  population  standard  deviation  (based  on  n  rather  than  on  (n-1)) 

of  each  column  in  EDATA  matrix. 
PVAR:  shows  population  variance  of  each  column  in  EDATA  matrix. 
MINE:  shows  average  of  each  column  in  EDATA  matrix. 

The  PLOT  sub-menu 

The  PLOT  sub-menu  contains  functions  that  are  used  to  produce  plots  with  the 
data  in  the  EDATA  matrix. 


The  functions  included  are: 

BARPL;  produces  a  bar  plot  with  data  in  Xcol  column  of  the  EDATA  matrix. 
HISTP:  produces  histogram  of  the  data  in  Xcol  column  in  the  EDATA  matrix, 
using  the  default  width  corresponding  to  1  3  bins  unless  the  bin  size  is 
modified  using  function  BINS  in  the  1  VAR  sub-menu  (see  above). 
SCATR:  produces  a  scatterplot  of  the  data  in  Ycol  column  of  the  EDATA 
matrix  vs.  the  data  in  Xcol  column  of  the  EDATA  matrix.  Equation 
fitted  will  be  stored  in  the  variable  EG. 
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The  FIT  sub-menu 

The  FIT  sub-menu  contains  functions  used  to  fit  equations  to  thie  data  in 
columns  Xcol  and  Ycol  of  tfie  2DATA  matrix. 


l: 

l: 

ELinEl   LR   IPREDXIPREDYI         1  COV 

RC4VI         1         1         1  I^TAT 

The  functions  available  in  this  sub-menu  are: 

SLINE:  provides  the  equation  corresponding  to  the  most  recent  fitting. 

LR:  provides  intercept  and  slope  of  most  recent  fitting. 
PREDX:  used  as  y  IlLiiiiill],  given  y  find  x  for  the  fitting  y  =  f(x). 
PREDY:  used  as  x  UMSl,  given  x  find  y  for  the  fitting  y  =  f(x). 
CORR:  provides  the  correlation  coefficient  for  the  most  recent  fitting. 
GOV:  provides  sample  co-variance  for  the  most  recent  fitting 
PCOV:  shows  population  co-variance  for  the  most  recent  fitting. 

The  SUMS  sub-menu 

The  SUMS  sub-menu  contains  functions  used  to  obtain  summary  statistics  of 
the  data  in  columns  Xcol  and  Ycol  of  the  ZDATA  matrix. 


EX  :  provides  the  sum  of  values  in  Xcol  column. 
SY  :  provides  the  sum  of  values  in  Ycol  column. 
2X'^2  :  provides  the  sum  of  squares  of  values  in  Xcol  column. 
SY'^2  :  provides  the  sum  of  squares  of  values  in  Ycol  column. 
EX*Y:  provides  the  sum  of  x-y,  i.e.,  the  products  of  data  in  columns  Xcol  and 
Ycol. 

NS  :  provides  the  number  of  columns  in  the  SDATA  matrix. 

Example  of  STAT  menu  operations 

Let  2DATA  be  the  matrix  shov/n  in  next  page. 

•  Type  the  matrix  in  level  1  of  the  stack  by  using  the  Matrix  Writer. 

•  To  store  the  matrix  into  EDATA,  use:  silllliiil  I  <n  J  IciilLli 
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•     Calculate  statistics  of  each  column:  ---- 

ma 


[nxt} 


produces  [38.5  87.5  82799.8] 
produces  [5.5.  12.5  1  1828.54...] 
produces  [3.39...  6.78...  21097.01...] 
produces  [10  21.5  55066] 
produces  [1.1  3.7  7.8] 
produces  [1 1.52  46.08  445084146.33] 
produces  [3.142...  6.284...  19532.04...] 
produces  [9.87...   39.49...  381500696.85. 


Data: 


1.1 

3.7 

7.8 

3.7 

8.9 

101 

2.2 

5.9 

25 

5.5 

12.5 

612 

6.8 

15.1 

2245 

9.2 

19.9 

24743 

10.0 

21.5 

55066 

•     Generate  a  scatterplot  of  the  data  in  columns  1  and  2  and  fit  a  straight 
line  to  it: 


B€r^i?i:'3  E^i?p?i?i  irirKT;x-3 

tauiu  ESAiU]  in-ri-ii 


resets  statistical  parameters 


6: 

Xcol:  1. 
Vcol:  2. 
Intercept:  0. 
Slope:  0. 
Model:  LIHFIT 


KCOL   VCOL   HODL   EPflR  RESET  IFIFO 


I  ..^  \  pS^n  WTrmxi  pnivTiv 
[NXT)  e3i.iJ1  UKJl  Eia Jla 


produces  scatterplot 

draws  data  fit  as  a  straight  line 
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ZOOM  UKjY)|TRflCE|  FCn  |  EDIT  |CflnCL 


SS3I!33  returns  to  main  display 

Determine  the  fitting  equation  and  some  of  its  statistics: 


3  IliliL 

1 


produces  'l.5+2*x' 

produces  Intercept:   1.5,   Slope:  2 

produces  0.75 

produces  3.  50 

produces  1 .0 

produces  23.04 

produces  1 9.74... 


Obtain  summary  statistics  for  data  in  columns  1  and  2:  ISIjiIIj  iailila: 


produces  38.5 
produces  87.5 
produces  280.87 
produces  1 370.23 
produces  61 9.49 
produces  7 


Fit  data  using  columns  1  (x)  and  3  (y)  using  a  logaritfimic  fitting: 


[f^xT]  smmass  icuiia  o  uiaas 


select  Ycol  =  3,  and 
select  Model  =  Logfit 


6: 

Xcol:  1. 
Vcol:  3. 
Intercept:  1.5 
Slope:  2. 
Model:  LOGFIT 


KCOL   VCOL   HODL   EPflR  RESET  IFIFO 
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s'sv2':i:-2  !!-:>raRiir:i  iKiCRiir:!?! 
L^XTj  ErUiJLl  UUUl  EUiUm 


produce  scattergram  of  y  vs.  x 
show  line  for  log  fitting 


ZOOM  UKjY)|TRflCE|  FCnf  EPIT  ICflnCL 


obviously,  tfie  log-fit  is  not  a  good  cfioice. 

IaBSm  returns  to  normal  display. 

•     Select  tfie  best  fitting  by  using: 

iSSTII]  ElZSa  tlUE!  □1^133         shows  EXPFIT  as  the  best  fit  for  these  data 


6: 


Intercept:       654532 1S£ 
Slope:  .992727735591 
Model:  EXPFIT 


XCOL  I  YCOL  I  HODL  |  EPHR  |RE£ET|  inFO 


(W]i^iEBI  Q^lil  lilillll  produces '2.6545*EXP(0.9927*X)' 

Haaa  produces  0.99995...  (good  correlation) 

2300  133333  produces  6.8 1 39 

5.2mm  produces  463.37 

[hxt)  iisiijj  jjji-iiiji  lEliljIyjIii  produce  scattergram  of  y  vs.  x 

!§i]3i]3  shov/  line  for  log  fitting 


ZOOM  |(K,V)|TRflCE|  FCn  |  EDIT  |CflnCL 


To  return  to  STAT  menu  use:  ':■'"'•■':!' 
To  get  your  variable  menu  back  use:  I    j . 
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Confidence  intervals 

Statistical  inference  is  the  process  of  making  conclusions  about  a  population 
based  on  information  from  sample  data.    In  order  for  tfie  sample  data  to  be 
meaningful,  tfie  sample  must  be  random,  i.e.,  the  selection  of  a  particular 
sample  must  have  the  same  probability  as  that  of  any  other  possible  sample 
out  of  a  given  population.  The  follov/ing  are  some  terms  relevant  to  the 
concept  of  random  sampling: 

•  Population:  collection  of  all  conceivable  observations  of  a  process  or 
attribute  of  a  component. 

•  Sample:  sub-set  of  a  population. 

•  Random  sample:  a  sample  representative  of  the  population. 

•  Random  variable:  real-valued  function  defined  on  a  sample  space.  Could 
be  discrete  or  continuous. 

If  the  population  follows  a  certain  probability  distribution  that  depends  on 
a  parameter  9,  a  random  sample  of  observations  (Xi,X2,X3,...  ,  XJ,  of  size 
n,  can  be  used  to  estimate  0. 

•  Sampling  distribution:  the  joint  probability  distribution  of  Xi,X2,X3,...  ,  X„. 

•  A  statistic:  any  function  of  the  observations  that  is  quantifiable  and  does 
not  contain  any  unknov^n  parameters.  A  statistic  is  a  random  variable 
that  provides  a  means  of  estimation. 

•  Point  estimation:  when  a  single  value  of  the  parameter  0  is  provided. 

•  Confidence  interval:  a  numerical  interval  that  contains  the  parameter  0  at 
a  given  level  of  probability. 

•  Estimator:  rule  or  method  of  estimation  of  the  parameter  0. 

•  Estimate:  value  that  the  estimator  yields  in  a  particular  application. 

Example  1  -  Let  X  represent  the  time  (hours)  required  by  a  specific 
manufacturing  process  to  be  completed.  Given  the  following  sample  of  values 
of  X:  2.2    2.5    2.1    2.3    2.2.   The  population  from  where  this  sample  is 
taken  is  the  collection  of  all  possible  values  of  the  process  time,  therefore,  it  is 
an  infinite  population.  Suppose  that  the  population  parameter  we  are  trying 
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to  estimate  is  its  mean  value,  (x.  We  will  use  as  an  estimator  the  mean  value 

-  —     1  " 

of  the  sample,  X,  defined  by  (a  rule):  X  =  —  X.. 

n  ,=1 

For  the  sample  under  consideration,  the  estimate  of  \x  is  the  sample  statistic  x 
=  {2.2+2.5+2.1+2.3+2.2)75  =  2.36.  This  single  value  of  X,  namely  x  = 
2.36,  constitutes  a  point  estimation  of  the  population  parameter  (x. 

Estimation  of  Confidence  Intervals 

The  next  level  of  inference  from  point  estimation  is  interval  estimation,  i.e., 
instead  of  obtaining  a  single  value  of  an  estimator  we  provide  two  statistics,  a 
and  b,  which  define  an  interval  containing  the  parameter  9  with  a  certain 
level  of  probability.  The  end  points  of  the  interval  are  known  as  confidence 
limits,  and  the  interval  (a,b)  is  known  as  the  confidence  interval. 

Definitions 

Let  (C|,CJ  be  a  confidence  interval  containing  an  unknown  parameter  6. 

•  Confidence  level  or  confidence  coefficient  is  the  quantity  (1-a),  where  0  < 
a  <  1 ,  such  that  P[C|  <  9  <  CJ  =  1  ■  a,  where  P[  ]  represents  a 
probability  (see  Chapter  1 7).  The  previous  expression  defines  the  so- 
called  two-sided  confidence  limits. 

•  A  lower  one-sided  confidence  interval  is  defined  by  Pr[C|  <  9]  =  1  ■  a. 

•  An  upper  one-sided  confidence  interval  is  defined  by  Pr[9  <  C^]  =  1  -  a. 

•  The  parameter  a  is  known  as  the  significance  level.  Typical  values  of  a 
are  0.01,  0.05,  0.1,  corresponding  to  confidence  levels  of  0.99,  0.95, 
and  0.90,  respectively. 

Confidence  intervals  for  the  population  mean  when  the 
population  variance  is  known 

Let  X  be  the  mean  of  a  random  sample  of  size  n,  drawn  from  an  infinite 
population  with  known  standard  deviation  a.  The  100(1 -a)  %  [i.e.,  99%, 
95%,  90%,  etc.],  central,  two-sided  confidence  interval  for  the  population 
mean  (x  is  (  X-Za/r^/^n  ,  X+Zoi/2-a/Vn  ),  where  Za/2  is  a  standard  normal 
variate  that  is  exceeded  with  a  probability  of  a  /2.  The  standard  error  of 
the  sample  mean,  X,  is  -o/Vn. 
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The  one-sided  upper  and  lower  100(1 -a)  %  confidence  limits  for  the 
population  mean  n  are,  respectively,  X+Za-a/Vn  ,  and  X-z^-a/Vn  .  Thus,  a 
lower,  one-sided,  confidence  interval  is  defined  as  (-oo  ,  X+Za-o/^n),  and  an 
upper,  one-sided,  confidence  interval  as  (X-Za  a/Vn,-l-Go).    Notice  that  in 
these  last  two  intervals  we  use  the  value  z^,  rather  than  Za/2- 

In  general,  the  value  z^  in  the  standard  normal  distribution  is  defined  as  that 
value  of  z  whose  probability  of  exceedence  is  k,  i.e.,  Pr[Z>zJ  =  k,  or  Pr[Z<zJ 
=  1  -  k.   The  normal  distribution  was  described  in  Chapter  1 7. 

Confidence  intervals  for  the  population  mean  when  the 
population  variance  is  unknown 

Let  X  and  S,  respectively,  be  the  mean  and  standard  deviation  of  a  random 
sample  of  size  n,  drawn  from  an  infinite  population  that  follows  the  normal 
distribution  with  unknown  standard  deviation  ct.  The  lOO  (l-a)  %  [i.e.,  99%, 
95%,  90%,  etc.]  central  two-sided  confidence  interval  for  the  population  mean 
H,  is  (  X-  t„.i  „/2  -S  /Vn  ,  X-i-  t^.i  -S/Vn  ),  where  i„.-t^a/2 's  Student's  t  variate 
with  V  =  n-1  degrees  of  freedom  and  probability  a/2  of  exceedence. 

The  one-sided  upper  and  lower  1 00-  (1-a)  %  confidence  limits  for  the 
population  mean  |a  are,  respectively, 

X  +  Ui,  a/2  •  V Vn  ,  and  X-  t„.i  a/2  -S  /Vn. 

Small  samples  and  large  samples 

The  behavior  of  the  Student's  t  distribution  is  such  that  for  n>30,  the 
distribution  is  indistinguishable  from  the  standard  normal  distribution.  Thus, 
for  samples  larger  than  30  elements  when  the  population  variance  is  unknown, 
you  can  use  the  same  confidence  interval  as  when  the  population  variance  is 
known,  but  replacing  a  with  S.  Samples  for  which  n>30  are  typically  referred 
to  as  large  samples,  otherwise  they  are  small  samples. 

Confidence  interval  for  a  proportion 

A  discrete  random  variable  X  follows  a  Bernoulli  distribution  if  X  can  take  only 
two  values,  X  =  0  (failure),  and  X  =  1  (success).    Let  X  ~  Bernoulli(p),  where  p 


Page  1 8-24 


is  the  probability  of  success,  then  the  mean  value,  or  expectation,  of  X  is  E[X] 
=  p,  and  its  variance  is  Var[X]  =  p(l-p). 

If  on  experiment  involving  X  is  repeated  n  times,  and  k  successful  outcomes 
are  recorded,  then  an  estimate  of  p  is  given  by  p'=  k/n,  while  the  standard 
error  of  p'  is  Op'=  V(p  (l-p)/n)  .  In  practice,  the  sample  estimate  for  p,  i.e.,  p' 
replaces  p  in  the  standard  error  formula. 

For  a  large  sample  size,  n>30,  and  n-p  >  5  and  n-(l-p)>5,  the  sampling 
distribution  is  very  nearly  normal.  Therefore,  the  100(1 -a)  %  central  tvvo-sided 
confidence  interval  for  the  population  mean  p  is  (p'+Zoi/2-cjp.,  p'+Zoi/2-cyp'  ). 
For  a  small  sample  (n<30),  the  interval  can  be  estimated  as  (p'-tn.i,a/2'Op'/p'+tn. 

l,a/2'Cfp')- 

Sampling  distribution  of  differences  and  sums  of  statistics 

Let  Si  and  S2  be  independent  statistics  from  two  populations  based  on 
samples  of  sizes  ni  and  n2,  respectively.  Also,  let  the  respective  means  and 
standard  errors  of  the  sampling  distributions  of  those  statistics  be  j^s,  and  1^52/ 
and      and  CTs2/  respectively.    The  differences  between  the  statistics  from  the 

two  populations,  S1-S2,  have  a  sampling  distribution  with  mean  [i  s]-s2  =  l^si  ■ 
1^52,  and  standard  error  o  si_s2  =  (ctsi^+  052^)^^^.  Also,  the  sum  of  the  statistics 
T1+T2  has  a  mean  ^  5, +52  =  1^51  +Hs2,  and  standard  error  051+52  =  (051^  + 

^32^)^/^. 

Estimators  for  the  mean  and  standard  deviation  of  the  difference  and  sum  of 
the  statistics  Si  and  S2  are  given  by: 


In  these  expressions,  Xi  and  X2  are  the  values  of  the  statistics  Si  and  S2  from 
samples  taken  from  the  two  populations,  and  051^  and  052^  are  the  variances 
of  the  populations  of  the  statistics  Si  and  S2  from  which  the  samples  were 
taken. 
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Confidence  intervals  for  sums  and  differences  of  mean  values 

If  the  population  variances  ai^and  are  known,  the  confidence  intervals  for 
the  difference  and  sum  of  the  mean  values  of  the  populations,  i.e.,  (Xi±(i2j  are 
given  by: 


For  large  samples,  i.e.,  n,  >  30  and  >  30,  and  unknown,  but  equal, 
population  variances  ai^=  02^,  the  confidence  intervals  for  the  difference  and 
sum  of  the  mean  values  of  the  populations,  i.e.,  ^i±(i2/  are  given  by: 


If  one  of  the  samples  is  small,  i.e.,  n,  <  30  or     <  30,  and  with  unknown,  but 

equal,  population  variances  a-^^  =  Q21  we  can  obtain  a  "pooled"  estimate  of 
the  variance  of  (ii+(X2/  as  Sp^  =  [(ni-1  )-s,^+{n2-l  )-S2^]/(  n,+n2-2). 

In  this  case,  the  centered  confidence  intervals  for  the  sum  and  difference  of 
the  mean  values  of  the  populations,  i.e.,  (ii±(X2/  are  given  by: 

((X,  ±  X, )  -        •    ,  (X,  ±  X, )  + 1,^,,,  ■  s\ ) 

where  v  =  nT+n2-2  is  the  number  of  degrees  of  freedom  in  the  Student's  t 
distribution. 

In  the  last  two  options  we  specify  that  the  population  variances,  although 
unknown,  must  be  equal.  This  will  be  the  case  in  which  the  two  samples  are 
taken  from  the  same  population,  or  from  two  populations  about  which  we 
suspect  that  they  have  the  same  population  variance.   However,  if  we  have 
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reason  to  believe  that  the  two  unknown  population  variances  are  different,  we 
can  use  the  following  confidence  interval 

where  the  estimated  standard  deviation  for  the  sum  or  difference  is 


and  n,  the  degrees  of  freedom  of  the  t  variate,  are  calculated  using  the  integer 
value  closest  to 

{{Slln,)  +  {Slln,)f 
\iS'jn,)l{n,-m  +  \iSlln,)lin,-\)-\ 

Determining  confidence  intervals 

The  application  6.  Conf  Interval  can  be  accessed  by  using  L  r»  J  stat 
IS3SBI.  The  application  offers  the  following  options: 


a.z-ini:  ni-na.. 

3.Z-inT:  1  p.. 

H.z-inT:  Pi-pa.. 

S.T-inT:   1  H.. 

e.T-ini:  Hl-H2.. 

1         1         1  ICHnCLl 

OK 

These  options  are  to  be  interpreted  as  follows: 

1.  Z-INT:  1  (J,.:  Single  sample  confidence  interval  for  the  population  mean, 
(i,  with  known  population  variance,  or  for  large  samples  with  unknown 
population  variance. 

2.  Z-INT:  )^l-|i2.;  Confidence  interval  for  the  difference  of  the  population 
means,  [ly  with  either  known  population  variances,  or  for  large 
samples  with  unknown  population  variances. 
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3.  Z-INT:  1  p.:  Single  sample  confidence  interval  for  the  proportion,  p,  for 
large  samples  with  unknown  population  variance. 

4.  Z-INT:  pi-  p2.:  Confidence  interval  for  the  difference  of  two  proportions, 
Pi-p2,  for  large  samples  with  unknown  population  variances. 

5.  T-INT:  1        Single  sample  confidence  interval  for  the  population  mean, 
|a,  for  small  samples  with  unknown  population  variance. 

6.  T-INT:  (xl-(j,2.:    Confidence  interval  for  the  difference  of  the  population 
means,      \i2>  fo""  small  samples  with  unknown  population  variances. 

Example  1  -  Determine  the  centered  confidence  interval  for  the  mean  of  a 
population  if  a  sample  of  60  elements  indicate  that  the  mean  value  of  the 
sample  is  x  =  23.2,  and  its  standard  deviation  is  s  =  5.2.  Use  a  =  0.05. 
The  confidence  level  is  C  =  1-a  =  0.95. 

Select  case  1  from  the  menu  shown  above  by  pressing  nSuHlS.  Enter  the  values 
required  in  the  input  form  as  shown: 


»conF.  inr.:  i 

EDIT  1         1  HELP  1         ICHnCLI  OK 

Press  lliiilia  to  obtain  a  screen  explaining  the  meaning  of  the  confidence 
interval  in  terms  of  random  numbers  generated  by  a  calculator.  To  scroll 
down  the  resulting  screen  use  the  down-arrow  key  .  Press  luQBS  when 
done  with  the  help  screen.  This  will  return  you  to  the  screen  shown  above. 

To  calculate  the  confidence  interval,  press  SESSS.  The  result  shown  in  the 
calculator  is:   

Critical  z=±l.  959964 
n  Hin  =21.93424 
V.  »iy.  =£4.61576 


HELP  iGRHPHlCHnCLl  OK 
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The  result  indicates  that  a  95%  confidence  interval  has  been  calculated.  The 
Critical  z  value  shown  in  the  screen  above  corresponds  to  the  values  ±Za/2  in 
the  confidence  interval  formula  (  X-Za/r^/^n  ,  X+z^/j-a/Vn  ).  The  values  (x 
Min  and  |a  Max  are  the  lov/er  and  upper  limits  of  this  interval,  i.e.,  (x  Min  = 
X-Zci/2-o/Vn,  and  n  Max  =  X+Zci/2-o/Vn. 

Press  nZEuGIII  to  see  a  graphical  display  of  the  confidence  interval  information: 


0 

-1.S5! 

JSSH      Crit.  Z  *  l.S 

Han          CI  aH.( 

23,3 

1  1 

HELP  1  TEKT  ICflnCLl  OK 

The  graph  shows  the  standard  normal  distribution  pdf  (probability  density 
function),  the  location  of  the  critical  points  ±z„/2,  the  mean  value  (23.2)  and 
the  corresponding  interval  limits  (21.88424  and  24.51576).  Press  to 
return  to  the  previous  results  screen,  and/or  press  i™..™  to  exit  the  confidence 
interval  environment.    The  results  will  be  listed  in  the  calculator's  display. 

Example  2  -  Data  from  two  samples  (samples  1  and  2)  indicate  that  x,  = 
57.8  and  X2  =  60.0.  The  sample  sizes  are  n^  =  45  and  n2  =  75.  If  it  is 
known  that  the  populations'  standard  deviations  are  Oi  =  3.2,  and  CT2  =  4.5, 
determine  the  90%  confidence  interval  for  the  difference  of  the  population 
means,  i.e.,  nr  1x2- 

Press  L J  IIIIEIIiito  access  the  confidence  interval  feature  in  the 

calculator.  Press  "^^SlSil  to  select  option  2.  Z-INT:  \i  1  -  [i2..  Enter  the 
following  values: 


»conF.  inr.: 

a     KnoHn  T^m 

|na:60. 

rt:3.2 

Ta:4.5 

11:45. 

na:75. 

C:  .9 

EDIT  1         1  HELP  1         ICHnCLI  OK 

When  done,  press  iEGlil.  The  results,  as  text  and  graph,  are  shown  below: 
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Critical  Z=±1.644S54 
Hin  =-3.360241 
»iy.  =-1.039759 


HELP  GRHPH  CHnCL  OK 


0 

-l.SHHS 
-3.3SDa 

5H      Crit.  Z  *  1 
11      SD.K  CI  *  -1 

-a.  a 

SHHS5H 

All 

1         1  HELP  1  TEKT  ICflnCLl  OK 

The  variable  A\i  represents  ^  1  -  \i2. 

Example  3  -  A  survey  of  public  opinion  indicates  that  in  a  sample  of  1  50 
people  60  favor  increasing  property  taxes  to  finance  some  public  projects. 
Determine  the  99%  confidence  interval  for  the  population  proportion  that 
v/ould  favor  increasing  taxes. 

Press  ir*j  .JW      IKliiBto  access  the  confidence  interval  feature  in  the 
calculator.    Press  SSIIB  to  select  option  3.  Z-INT:  (j,  1  -  |a2..  Enter 

the  follov/ing  values: 


When  done,  press  I 


The  results,  as  text  and  graph,  are  shov/n  belov/: 


Critical  z=±2.575S29 
n  Hin  =  .2969663 
n  »iy.  =  .5030332 


HELP  CRHPH  CHnCL  OK 


0 

_ : 

-a 

.2 

.5?53aS      Crit.  Z  *  Z.575S 
SSSSSS      SS.Z  CI  *  .503033 

Z 

n 

1  1 

HELP  1  TEKT  |CflnCL| 

Example  4  -  Determine  a  90%  confidence  interval  for  the  difference  between 
two  proportions  if  sample  1  shows  20  successes  out  of  1 20  trials,  and  sample 
2  shows  1 5  successes  out  of  1 00  trials. 
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Press  ( j:^!  stat  "" to  access  the  confidence  interval  feature  in  tfie 
calculator.    Press  liSSii  to  select  option  4.  Z-INT:  pi  -  p2.. 

Enter  the  following  values: 


.9 


na:  100. 


when  done,  press  SESSS.  The  results,  as  text  and  graph,  are  shown  below: 


Critical  Z=±1.644S54 
in  Hin  =-.0644566 
in  »iy.  =  .09773993 


HELP  CRHPH  CHnCL  OK 


0 

-1.SHH3 
-.DSHH5( 

5H      Crit.  Z  *  1 

;s  *  M.y.  CI  *  .0 

SHHSSH 

in 

1         1  HELP  1  TEXT  ICHnCLl  OH 

Example  5  -  Determine  a  95%  confidence  interval  for  the  mean  of  the 
population  if  a  sample  of  50  elements  has  a  mean  of  1 5.5  and  a  standard 
deviation  of  5.  The  population's  standard  deviation  is  unknown. 


Press  Cg3 OiliSiJiillf  to  access  the  confidence  interval  feature  in  the 
calculator.    Press  iiililS  to  select  option  5.  T-INT:  [i.    Enter  the 

following  values: 


^conr.  ini. 

1  Kj  unnnoHn 

fx:  5. 

50. 

C:  .95 

EDIT  1         1  HELP  1         ICHnCLI  OH 

When  done,  press 


The  results,  as  text  and  graph,  are  shown  below: 
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Critical  T=±2.  009575 
k  Hin  =14.07902 

V.  »iy.  =16.92093 


HELP  GRHPH  CHnCL  OK 


0 

1 

-3.0 
1H.D7 

[J55?5  Krit.  T-f  1.00 
SOa      S5.^  CI  ICS 
15,5 

S5?5 
105S 

1  1 

HELP  1  TEKT  |CflnC 

L|  OH 

The  figure  shows  the  Student's  t  pdf  for  v  =  50  -  1  =49  degrees  of  freedom. 

Example  6  -  Determine  the  99%  confidence  interval  for  the  difference  in 
means  of  two  populations  given  the  sample  data:      =  1 57.8  ,  X2  =  1 60.0, 
n^  =  50,  n2  =  55.   The  populations  standard  deviations  are  Si  =  1  3.2,  S2  = 
24.5. 


Press  ir*j .JW      iEIIIm  to  access  the  confidence  interval  feature  in  the 
calculator.    Press       BEI138  to  select  option  6.  T-INT:  (j,l-^2..    Enter  the 
following  values: 


^conr.  ini.:  2 

unnnoHn 

Jl:  157. S 

na:  160. 

Jl:  13.2 

sa:24.5 

11:50. 

na:55. 

C:  .99 

gp««l.«4 

P'««l.4d  if  ch«cH«d 

EDIT  I^CHKI  HELP 

ICHnCLI  OH 

hen  done,  press  S3SE5!.  The  results,  as  text  and  graph,  are  shown  below: 


Critical  T=±2.  635632 

Hin  =-12.20093 

»iy.  =7.300973 


HELP  CRHPH  CHnCL  OH 


.--^  0 

_  1 

-1 

a.S35S3a  Krit.  T-f  a.S35S3; 
3.1005S      55. y.  CI  *  7.S00'ii 

-a.  a 

1  1 

HELP  1  TEKT  ICflnCLl  ( 

H 

These  results  assume  that  the  values  Si  and  S2  are  the  population  standard 
deviations.  If  these  values  actually  represent  the  samples'  standard 
deviations,  you  should  enter  the  same  values  as  before,  but  with  the  option 
_pooled  selected.    The  results  now  become: 
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Critical  T=±2.  624406 
Hin  =-12.42526 
hoj:  =3.025261 


HELP  GRHPH  CHnCL  OK 


-a.SaHHDS  Krit.  T-f  a.SaHHDS 

-la.Hasas  ci  *  s.oism 
_j  -a,  a  
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Confidence  intervals  for  the  variance 

To  develop  a  formula  for  the  confidence  interval  for  thie  variance,  first  we 
introduce  the  sampling  distribution  of  the  variance:  Consider  a  random 
sample  X,,  Xj      X„  of  independent  normally-distributed  variables  v/ith  mean 
[I,  variance  ct^,  and  sample  mean  X.  The  statistic 

n-l  M 

is  an  unbiased  estimator  of  the  variance  ct^. 

^2  n   

The  quantity  (n  —  V)  — j  =  ^ (X.  —  XY ,  has  a  Xn-i^  (chi-square) 

o-  ,=1 

distribution  v/ith  v  =  n-l  degrees  of  freedom.  The  (l-a)-lOO  %  tv^o-sided 
confidence  interval  is  found  from 

Pr[x^-i,i-a/2  <  (n-l)-SVa2  <  x^.i,a/2]  =  1-  «■ 
The  confidence  interval  for  the  population  variance  ct^  is  therefore, 

[{n-l)-SVx^.i,a/2;(n-l)-SVx'n.i,i.a/2]- 

v/here  x^n-i,a/2  /  arid  x^n  i,i  a/2  are  the  values  that  a  x^  variable,  v/ith  v  =  n-l 
degrees  of  freedom,  exceeds  v/ith  probabilities  a/2  and  1-  a  /2,  respectively. 

The  one-sided  upper  confidence  limit  for  ct^  is  defined  as  (n-l  )  SV  X^n  i,i-a- 

Example  1  -  Determine  the  95%  confidence  interval  for  the  population 
variance     based  on  the  results  from  a  sample  of  size  n  =  25  that  indicates 
that  the  sample  variance  is  s^  =  1 2.5. 
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In  Chapter  1 7  we  use  the  numerical  solver  to  solve  the  equation  a  = 
UTPC(y,x).  In  this  program,  y  represents  the  degrees  of  freedom  (n-1),  and  a 
represents  the  probability  of  exceeding  a  certain  value  of  x  (x^),  i.e.,  Pr[x^  > 
Xa^]  =  a- 

For  the  present  example,  a  =  0.05,  y  =  24  and  a  =  0.025.  Solving  the 
equation  presented  above  results  in  x^n-i,a/2  =  X^24,o.o25  =  39.3640770266. 

On  the  other  hand,  the  value  x^ni,a/2  =  X^24,o975  is  calculated  by  using  the 
values  y  =  24  and  a  =  0.975.  The  result  is  x^ni,i.a/2  =  X^24,o.975  = 
12.4011502175. 

The  lower  and  upper  limits  of  the  interval  will  be  (Use  ALG  mode  for  these 
calculations): 

(n-l)-SVx'n.i,a/2  =  (25-1  )-l  2.5/39.3640770266  =  7.621 16179676 
(n-1  )SV  x'„-i,i-a/2  =  (25-1  )1 2.5/1 2.401 1 5021 75  =  24.1 91 3044144 
Thus,  the  95%  confidence  interval  for  this  example  is: 

7.621 16179676  <     <  24.1913044144. 

Hypothesis  testing 

A  hypothesis  is  a  declaration  made  about  a  population  (for  instance,  with 
respect  to  its  mean).  Acceptance  of  the  hypothesis  is  based  on  a  statistical 
test  on  a  sample  taken  from  the  population.  The  consequent  action  and 
decision-making  are  called  hypothesis  testing. 

The  process  of  hypothesis  testing  consists  on  taking  a  random  sample  from  the 
population  and  making  a  statistical  hypothesis  about  the  population.  If  the 
observations  do  not  support  the  model  or  theory  postulated,  the  hypothesis  is 
rejected.  However,  if  the  observations  are  in  agreement,  then  hypothesis  is 
not  rejected,  but  it  is  not  necessarily  accepted.  Associated  with  the  decision 
is  a  level  of  significance  a. 
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Procedure  for  testing  hypotheses 

The  procedure  for  hypothesis  testing  involves  the  following  six  steps: 

1 .  Declare  a  null  hypothesis,  Hg.  This  is  the  hypothesis  to  be  tested.  For 
example,  Hq:  =  0/  i-e.,  we  hypothesize  that  the  mean  value  of 
population  1  and  the  mean  value  of  population  2  are  the  same.  If  Hq  is 
true,  any  observed  difference  in  means  is  attributed  to  errors  in  random 
sampling. 

2.  Declare  an  alternate  hypothesis,  H,.  For  the  example  under  consideration, 
it  could  be  Hi:  1^1-^2  *  0  [Note:  this  is  v/hat  v/e  really  want  to  test.] 

3.  Determine  or  specify  a  test  statistic,  T.  In  the  example  under  consideration, 
T  will  be  based  on  the  difference  of  observed  means,  X,-  X2. 

4.  Use  the  known  (or  assumed)  distribution  of  the  test  statistic,  T. 

5.  Define  a  rejection  region  (the  critical  region,  R)  for  the  test  statistic  based 
on  a  pre-assigned  significance  level  a. 

6.  Use  observed  data  to  determine  whether  the  computed  value  of  the  test 
statistic  is  within  or  outside  the  critical  region.  If  the  test  statistic  is  within 
the  critical  region,  then  we  say  that  the  quantity  we  are  testing  is 
significant  at  the  100a  percent  level. 

Notes;  

1.  For  the  example  under  consideration,  the  alternate  hypothesis  Hf-.  Hi-|i2  ^ 
0  produces  what  is  called  a  two-tailed  test.  If  the  alternate  hypothesis  is 
Hi:  nrH2  >  0  or  Hi:  ^1-^2  <  0,  then  we  have  a  one-tailed  test. 

2.  The  probability  of  rejecting  the  null  hypothesis  is  equal  to  the  level  of 
significance,  i.e.,  Pr[TGR |  Ho]=a.  The  notation  Pr[A|B]  represents  the 
conditional  probability  of  event  A  given  that  event  B  occurs. 


Errors  in  hypothesis  testing 

In  hypothesis  testing  we  use  the  terms  errors  of  Type  I  and  Type  II  to  define  the 
cases  in  which  a  true  hypothesis  is  rejected  or  a  false  hypothesis  is  accepted 
(not  rejected),  respectively.  Let  T  =  value  of  test  statistic,  R  =  rejection  region, 
A  =  acceptance  region,  thus,  RnA  =  0,  and  RuA  =  Q,  where  D.  =  the 
parameter  space  for  T,  and  0  =  the  empty  set.  The  probabilities  of  making 
an  error  of  Type  I  or  of  Type  II  are  as  follows: 
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Rejecting  a  true  hypothesis,  Pr[Type  I  error]  =  Pr[TeR|  Hq]  =  a 
Not  rejecting  a  false  hypothesis,  Pr[Type  II  error]  =  Pr[TeA|       =  p 

Now,  let's  consider  the  coses  in  which  we  moke  the  correct  decision: 

Not  rejecting  a  true  hypothesis,  Pr[Not(Type  I  error)]  =  Pr[Te A  |  Hq]  =  1  -  a 

Rejecting  a  false  hypothesis,    Pr[Not(Type  II  error)]  =  Pr  [TeR|  Hi]  =  1  - 13 

The  complement  of  p  is  called  the  power  of  the  test  of  the  null  hypothesis  Hg 
vs.  the  alternative  Hi.  The  power  of  a  test  is  used,  for  example,  to  determine 
a  minimum  sample  size  to  restrict  errors. 

Selecting  values  of  a  and  p 

A  typical  value  of  the  level  of  significance  (or  probability  of  Type  I  error)  is  a 
=  0.05,  (i.e.,  incorrect  rejection  once  in  20  times  on  the  average).  If  the 
consequences  of  a  Type  I  error  are  more  serious,  choose  smaller  values  of  a, 
say  0.01  or  even  0.001. 

The  value  of  p,  i.e.,  the  probability  of  making  an  error  of  Type  II,  depends  on 
a,  the  sample  size  n,  and  on  the  true  value  of  the  parameter  tested.  Thus,  the 
value  of  p  is  determined  after  the  hypothesis  testing  is  performed.  It  is 
customary  to  draw  graphs  showing  p,  or  the  power  of  the  test  (1-p),  as  a 
function  of  the  true  value  of  the  parameter  tested.  These  graphs  are  called 
operating  characteristic  curves  or  power  function  curves,  respectively. 

Inferences  concerning  one  mean 

Two-sided  hypothesis 

The  problem  consists  in  testing  the  null  hypothesis  H,,:  |a  =  la^,  against  the 
alternative  hypothesis,  Hii  n^yio  at  a  level  of  confidence  (l-a)100%,  or 
significance  level  a,  using  a  sample  of  size  n  with  a  mean  x  and  a  standard 
deviation  s.  This  test  is  referred  to  as  a  two-sided  or  two-tailed  test.  The 
procedure  for  the  test  is  as  follows: 
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First,  we  calculate  the  appropriate  statistic  for  the  test  (t^,  or  zj  as  follows: 


If  n  <  30  and  the  standard  deviation  of  the  population,  o,  is  known, 

use  trie  z-statistic:  =  = 

cr/ v« 

If  n  >  30,  and  a  is  known,  use      as  above.    If  ct  is  not  known. 


replace  s  for  a  in  z^,  i.e.,  use       =  ■ 


X  —  Li 

•  If  n  <  30,  and  o  is  unknown,  use  the  t-statistic     =  j^,  with  v  = 

s/^|n 

n  -  1  degrees  of  freedom. 

Then,  calculate  the  P-value  (a  probability)  associated  with  either  Zo  or  to  ,  and 
compare  it  to  a  to  decide  whether  or  not  to  reject  the  null  hypothesis.  The  P- 
value  for  a  two-sided  test  is  defined  as  either 

P-value  =  P(|z|>|zJ),  or,  P-value  =  P(|t|>|tJ). 

The  criteria  to  use  for  hypothesis  testing  is: 

•  Reject     if  P-value  <  a 

•  Do  not  reject     if  P-value  >  a. 

The  P-value  for  a  two-sided  test  can  be  calculated  using  the  probability 
functions  in  the  calculator  as  follows: 


If  using  z,  P-value  =  2  UTPN(0, 1 ,  |  zj ) 
If  using  t,  P-value  =  2-UTPT(v,  |  tj ) 


Example  1  ~  Test  the  null  hypothesis  H^:  |a  =  22.5  (  =  [i^),  against  the 
alternative  hypothesis.  Hi:  |a^22.5,  at  a  level  of  confidence  of  95%  i.e.,  a  = 
0.05,  using  a  sample  of  size  n  =  25  with  a  mean  x  =  22.0  and  a  standard 
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deviation  s  =  3.5.  We  assume  that  we  don't  know  the  value  of  the  population 
standard  deviation,  therefore,  we  calculate  a  t  statistic  as  follows: 
,  _  22.0-22.5  _  ,,,,, 

"     sl4^  3.5/ 
The  corresponding  P-value,  for  n  =  25  -  1  =  24  degrees  of  freedom  is 

P-value  =  2UTPT(24,-0.7142)  =  20.7590  =  1.5169, 

since  1.5169  >  0.05,  i.e.,  P-value  >  a,  we  cannot  reject  the  null  hypothesis 
H„:  \y  =  22.0. 

One-sided  hypothesis 

The  problem  consists  in  testing  the  null  hypothesis  \-\^:  \x  =  yi^,  against  the 
alternative  hypothesis.  Hi:  |a>|io  or  Hi:  |i  <  at  a  level  of  confidence  (1- 
a)100%,  or  significance  level  a,  using  a  sample  of  size  n  with  a  mean  x  and 
a  standard  deviation  s.  This  test  is  referred  to  as  a  one-sided  or  one-tailed 
test.  The  procedure  for  performing  a  one-side  test  starts  as  in  the  two-tailed 
test  by  calculating  the  appropriate  statistic  for  the  test  (t^  or  zj  as  indicated 
above. 

Next,  we  use  the  P-value  associated  with  either  Zo  or  to  ,  and  compare  it  to  a 
to  decide  whether  or  not  to  reject  the  null  hypothesis.  The  P-value  for  a  two- 
sided  test  is  defined  as  either 

P-value  =  P{z  >  I  zj ),  or,  P-value  =  P{t  >  |  tj ). 

The  criteria  to  use  for  hypothesis  testing  is: 

•  Reject  Ho  if  P-value  <  a 

•  Do  not  reject  H^  if  P-value  >  a. 

Notice  that  the  criteria  are  exactly  the  same  as  in  the  two-sided  test.  The  main 
difference  is  the  way  that  the  P-value  is  calculated.  The  P-value  for  a  one- 
sided test  can  be  calculated  using  the  probability  functions  in  the  calculator  as 
follows: 


V25 
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•  If  using  z,         P-value  =  UTPN(0, 1  ,zj 

•  If  using  t,  P-value  =  UTPT(v,tJ 

Example  2  -  Test  the  null  hypotfiesis  H^:  |a  =  22.0  (  =  n^),  against  tfie 
alternative  fiypotfiesis.  Hi:  |a>22.5  at  a  level  of  confidence  of  95%  i.e.,  a  = 
0.05,  using  a  sample  of  size  n  =  25  witfi  a  mean  x  =  22.0  and  a  standard 
deviation  s  =  3.5.  Again,  we  assume  tfiat  we  don't  know  tfie  value  of  the 
population  standard  deviation,  therefore,  the  value  of  the  t  statistic  is  the  same 
as  in  the  two-sided  test  case  shown  above,  i.e.,  to=  -0.7142,  and  P-value,  for 
V  =  25  -  1  =  24  degrees  of  freedom  is 

P-value  =  UTPT(24,  | -0.71 42 1)  =  UTPT(24,0.71 24)  =  0.2409, 

since  0.2409  >  0.05,  i.e.,  P-value  >  a,  we  cannot  reject  the  null  hypothesis 
H„:  n  =  22.0. 

Inferences  concerning  two  means 

The  null  hypothesis  to  be  tested  is  H^:  |ai-|i2  =  8,  at  a  level  of  confidence  (1- 
a)100%,  or  significance  level  a,  using  two  samples  of  sizes,  n,  and  n2,  mean 
values  Xi  and  X2,  and  standard  deviations  Si  and  S2.  If  the  populations 
standard  deviations  corresponding  to  the  samples,  ai  and  02,  are  known,  or 
if  n^  >  30  and  n2  >  30  (large  samples),  the  test  statistic  to  be  used  is 


If  ni  <  30  or  n2  <  30  (at  least  one  small  sample),  use  the  following  test  statistic: 

^      VK-1K+(«2-1>2'    V  "l+«2 
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Two-sided  hypothesis 

If  the  alternative  hypothesis  is  a  two-sided  hypothesis,  i.e.,  Hi:  \i^-\i2  S/  The 
P-value  for  this  test  is  calculated  as 

If  using  z,         P-value  =  2  UTPN(0,1,  |z,|) 

•  If  using  t,  P-value  =  2-UTPT(v,  |  tj ) 

with  the  degrees  of  freedom  for  the  t-distribution  given  by  v  =  n,  -i-  n2  -  2.  The 
test  criteria  are 

•  Reject  Ho  if  P-value  <  a 

•  Do  not  reject  H^  if  P-value  >  a. 

One-sided  hypothesis 

If  the  alternative  hypothesis  is  a  two-sided  hypothesis,  i.e..  Hi:  <  §/  or, 
H,:  (ii-(j,2  <  8„  the  P-value  for  this  test  is  calculated  as: 

•  If  using  z,         P-value  =  UTPN(0, 1 ,  |  zj ) 

•  If  using  t,  P-value  =  UTPT(v,  1 1„  | ) 

The  criteria  to  use  for  hypothesis  testing  is: 

•  Reject  Hq  if  P-value  <  a 

•  Do  not  reject  H^,  if  P-value  >  a. 

Paired  sample  tests 

When  we  deal  with  two  samples  of  size  n  with  paired  data  points,  instead  of 
testing  the  null  hypothesis,  H,,:  1^1-^2  =  8/  using  the  mean  values  and  standard 
deviations  of  the  two  samples,  we  need  to  treat  the  problem  as  a  single 
sample  of  the  differences  of  the  paired  values.  In  other  words,  generate  a 
new  random  variable  X  =  X1-X2,  and  test  H^:  n  =  5,  where  |a  represents  the 
mean  of  the  population  for  X.  Therefore,  you  will  need  to  obtain  x  and  s  for 
the  sample  of  values  of  x.  The  test  should  then  proceed  as  a  one-sample  test 
using  the  methods  described  earlier. 
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Inferences  concerning  one  proportion 

Suppose  that  we  want  to  test  the  null  hypothesis,  Hq:  p  =  po,  where  p 
represents  the  probability  of  obtaining  a  successful  outcome  in  any  given 
repetition  of  a  Bernoulli  trial.  To  test  the  hypothesis,  we  perform  n  repetitions 
of  the  experiment,  and  find  that  k  successful  outcomes  are  recorded.  Thus,  an 
estimate  of  p  is  given  by  p'  =  k/ n. 

The  variance  for  the  sample  will  be  estimated  as  Sp^=  p'(l-p')/n  =  k-(n-k)/n^. 

Assume  that  the  Z  score,  Z  =  (p-po)/sp,  follows  the  standard  normal 
distribution,  i.e.,  Z  ~  N(0, 1 ).  The  particular  value  of  the  statistic  to  test  is  Zq  = 
(p'-Po)/sp. 

Instead  of  using  the  P-value  as  a  criterion  to  accept  or  not  accept  the 
hypothesis,  we  will  use  the  comparison  between  the  critical  value  of  zO  and 
the  value  of  z  corresponding  to  a  or  a/2. 

Two-tailed  test 

If  using  a  two-tailed  test  we  will  find  the  value  of  z  01/2,  from 

Pr[Z>  z„/2]  =  l-cl)(z„/2)  =  a/2,  or  (I)(z  „/2)  =  l-a/2, 

where  <l>(z)  is  the  cumulative  distribution  function  (CDF)  of  the  standard  normal 
distribution  (see  Chapter  1 7). 

Reject  the  null  hypothesis,  Hq,  if  Zq  >Zoi/2,  or  if  Zq  <  -  Za/2. 

In  other  words,  the  rejection  region  is  R  =  {  |zo|  >  Za/2  },  while  the 
acceptance  region  is  A  =  { |  Zq  |  <  z„/2 }. 

One-tailed  test 

If  using  a  one-tailed  test  we  will  find  the  value  of  S,  from 
Pr[Z>  zj  =  l-O(za)  =  a,  or  (D(z  „)=!-«, 

Reject  the  null  hypothesis,  Hq,  if  ZQ>z.a,  and  H,:  p>Po,  or  if  Zq  <  -  Zd,  and  Hi: 
P<Po- 
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Testing  the  difference  between  two  proportions 

Suppose  that  we  want  to  test  the  null  hypothesis,  Hq:  pi-p2  =  Po/  where  the  p's 
represents  the  probability  of  obtaining  a  successful  outcome  in  any  given 
repetition  of  a  Bernoulli  trial  for  two  populations  1  and  2.  To  test  the 
hypothesis,  we  perform  n,  repetitions  of  the  experiment  from  population  1, 
and  find  that  ki  successful  outcomes  ore  recorded.  Also,  we  find  l<2  successful 
outcomes  out  of  nj  trials  in  sample  2.  Thus,  estimates  of  pi  and  p2are  given, 
respectively,  by  p/  =  ki/n^,  and  P2'  =  k2/n2. 

The  variances  for  the  samples  will  be  estimated,  respectively,  as 

Si^=  Pi'(l-Pi')/ni  =  kT(n,-k,)/n,3,  and  S2^=  P2'(l-p2')/n2  =  k2-(n2-k2)/n2^ 

And  the  variance  of  the  difference  of  proportions  is  estimated  from:  Sp^=  Si^  + 

S2^ 

Assume  that  the  Z  score,  Z  =  (prP2"Po)/Sp/  follows  the  standard  normal 
distribution,  i.e.,  Z  ~  N(0, 1).  The  particular  value  of  the  statistic  to  test  is  Zg  = 
(Pi'-P2'-Po)/sp. 

Two-tailed  test 

If  using  a  two-tailed  test  we  will  find  the  value  of  z  „/2,  from 

Pr[Z>  Za/2]  =  l-3>(za/2)  =  a/2,  or  (D(z  ^/i)  =  1-  a/2, 

where  <l>(z)  is  the  cumulative  distribution  function  (CDF)  of  the  standard  normal 
distribution. 

Reject  the  null  hypothesis,  Hq,  if  Zg  >Za/2,  or  if  Zg  <  -  Za/2. 

In  other  words,  the  rejection  region  is  R  =  {  |zo|  >  Zoi/2  },  while  the 
acceptance  region  is  A  =  { |  Zq  |  <  Za/2 }. 

One-tailed  test 

If  using  a  one-tailed  test  we  will  find  the  value  of  z^,  from 
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Pr[Z>  zj  =  l-(&(z„)  =  a,  or  (D{z  „)  =  1-  a, 

Reject  the  null  hypothesis,  Hq,  if  Zo>Zci,  and  Hi:  Pi-P2>  Poi  o""  if  <  -  z„,  and 
Hi:  pi-p2<Po- 

Hypothesis  testing  using  pre-programmed  features 

The  calculator  provides  with  hypothesis  testing  procedures  under  application 
5.  Hypoth.  tests.,  can  be  accessed  by  using         STAry^^^^  BIoBI. 

As  with  the  calculation  of  confidence  intervals,  discussed  earlier,  this  program 
offers  the  following  6  options: 


a.z-Uft:  ni-na.. 

3.Z-Hft:  1  p.. 

H.z-Uft:  Pi-pa.. 

S.T-Uft:   1  H.. 

e.T-T<ft:  Hl-H2.. 

1         1         1  ICHnCLl 

OK 

These  options  are  interpreted  as  in  the  confidence  interval  applications: 

1 .  Z-Test:  1  (x.:  Single  sample  hypothesis  testing  for  the  population  mean,  (x, 
with  known  population  variance,  or  for  large  samples  with  unknown 
population  variance. 

2.  Z-Test:  1x1-^2.:  Hypothesis  testing  for  the  difference  of  the  population 
means,  [i^-  with  either  known  population  variances,  or  for  large 
samples  with  unknown  population  variances. 

3.  Z-Test:  1  p.:  Single  sample  hypothesis  testing  for  the  proportion,  p,  for 
large  samples  with  unknown  population  variance. 

4.  Z-Test:  pi-  p2.:  Hypothesis  testing  for  the  difference  of  two  proportions, 
P1-P2,  for  large  samples  with  unknown  population  variances. 

5.  T-Test:  1  |a.:  Single  sample  hypothesis  testing  for  the  population  mean,  \i, 
for  small  samples  with  unknown  population  variance. 

6.  T-Test:  ^l-(x2.:  Hypothesis  testing  for  the  difference  of  the  population 
means,  (Xr  \i2,  for  small  samples  with  unknown  population  variances. 
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Try  the  following  exercises: 


Example  1  -  For  i^q  =  1  50,  a  =  1 0,  x  =  1 58,  n  =  50,  for  a  =  0.05,  test  the 
hypothesis  Hg:  (j,  =  [Iq,  against  the  alternative  hypothesis.  Hi:  (j,  ^  (Xq- 

Press  (j^l  sTATy^^'^  iullii  to  access  the  hypothesis  testing  feature  in  the 
calculator.    Press  ISuUSS  to  select  option  1 .  Z-Test:  1  (x. 

Enter  the  following  data  and  press  SlSSli: 


Hi): 

^Z-TEST:  1 

T:  10. 

X  '• 

15S. 

n- 

50. 

.05 

nuu 

hypothtf if 

EDIT  1         1  HELP  1         ICHnCLI  OK 

You  are  then  asked  to  select  the  alternative  hypothesis.  Select  (x  ^150,  and 
press  nUaS.  The  result  is: 


5.656S54 

Pr*b= 

1.541726E-S 

±1.959964 

{1147.2,  152. SJ 

\         \  HELP  IGRHPHICHnCLI  OK 

Then,  we  reject  Hq:  |a  =  150,  against  H^:  yi  ^  150.  The  test  z  value  is  Zq  = 
5.656854.  The  P-value  is  1.54x10'®.  The  critical  values  of  ±Za/2  = 
±1 .959964,  corresponding  to  critical  x  range  of  {147.2  152.8}. 


This  information  can  be  observed  graphically  by  pressing  the  soft-menu  key 


-1.S5SSSH  -Krit.  Z-^  1.55SSSH 

TsJt  2=5.656g5H| 
n=15g. 

iHz.aasa  +<rit.  ^*  i5a.??ig 


HELP   TEKT  CflnCL  OK 
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Example  2  -  For  [1q  =  150,  x  =  158,  s  =  10,  n  =  50,  for  a  =  0.05,  test  the 
hypothesis  Hq:  [i  =  y.Q,  against  the  alternative  hypothesis,  Hi:  |a  >  Ho-  The 
population  standard  deviation,  a,  is  not  known. 

Press  ( j^l  STAT /2s^  to  access  the  hypothesis  testing  feature  in  the 

calculator.    Press  KM  to  select  option  5.  T-Test:  1 

Enter  the  following  data  and  press  SSSSSS: 


^T-TEST:  1 

n:  50. 

n:  15S. 

Sx:  10. 

«:  .05 

EDIT  1         1  HELP  1         ICHnCLI  OK 

Select  the  alternative  hypothesis,  Hi:  (j,  >  1 50,  and  press  B33SI.  The  result  is: 

Tsjt  T=5.656S54 

pr(.b= .  000000393525 
Critical  7=1.676551 
Critical  n=  152. 371 


HELP  |CRHPH|CHnCL|  OK 


We  reject  the  null  hypothesis,  Hq:  Hq  =  ^  50,  against  the  alternative  hypothesis, 
Hi:  |a  >  150.  The  test  t  value  is  to  =  5.656854,  with  a  P-value  = 
0.000000393525.  The  critical  value  of  t  is  t^  =  1 .676551,  corresponding  to 
a  critical  x=  152.371. 

Press  IHEEGHII  to  see  the  results  graphically  as  follows: 


Crit.  T-f  l.S?S551 

TsJt  T=5 

.csessHl 

n=i5s. 1 

Crit.  n-f  15a.3?l 

150. 

H 

1         1  HELP  1  TEKT  ICflnCLl  OK 

Example  3  -  Data  from  two  samples  show  that  Xi  =  1  58,  Xi  =  1 60,  Si  = 
10,  S2  =  4.5,    nl  =  50,  and  n2  =  55.     For  a  =  0.05,  and  a  "pooled" 
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variance,  test  the  hypothesis  Hq:  (Xi-fi2  =  0,  against  the  alternative  hypothesis, 

H,:  ni-^i2  <  0. 

Press  [j^l  sTATyAS^/is,  SUSI  to  access  the  hypothesis  testing  feature  in  the 
calculator.  Press  :irT!||  to  select  option  6.  T-Test:  (il-(x2.:  Enter  the 
tollov^ing  data  and  press  "  "": 


^T-TEST 

:  2  unKnoHn 
■  n2:  160. 

si:  10. 

sa:  4.5 

ni:  50. 

na:  55. 

«:  .05 

SOHpl.«  H40n 

EDIT  1         1  HELP  1         ICHnCLI  OK 

Select  the  alternative  hypothesis  |j,l<  (x2,  and  press  SUSS.  The  result  is 


Hl=n2  It  S.y.  L'lL^Mi 

Hft  T= 

-1.341776 

Pr*b= 

.09130961 

cntiiiy  T= 

-1.6597S2 

1         1  HELP  IGRHPHICHnCLI  OK 

Thus,  we  accept  (more  accurately,  we  do  not  reject)  the  hypothesis:  Hq:  1^1-^2 
=  0,  or  Hq:  [ii=H2,  against  the  alternative  hypothesis  H,:  1^1-^2  <  0,  or  H,: 
|ai=|i2.  The  test  t  value  is  to  =  -1 .341 776,  with  a  P-value  =  0.091 30961 ,  and 
critical  t  is  -\a  =  -1 .659782.   The  graphical  results  are: 


-j 
-a 

L.S5S?Sa  *■  Crit.  T 
iTsJt  T=-1.3H1??6 

|in=-a. 

.H?H(JDS  -Krit. 
1          "  iK 

1  1 

HELP  1  TEKT  ICflnCLl  OK 

These  three  examples  should  be  enough  to  understand  the  operation  of  the 
hypothesis  testing  pre-programmed  feature  in  the  calculator. 
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Inferences  concerning  one  variance 

The  null  hypothesis  to  be  tested  is  ,  H^,:  =  a^,  at  a  level  of  confidence  (1- 
a)100%,  or  significance  level  a,  using  a  sample  of  size  n,  and  variance  s^. 
The  test  statistic  to  be  used  is  a  chi-squared  test  statistic  defined  as 

2_(»-iy 
^0 

Depending  on  the  alternative  hypothesis  chosen,  the  P-value  is  calculated  as 
follov/s: 

.     H, :     <  a,^  P-value  =  P(x'<Xo')  =  1  ■UTPC(v,Xo') 

.     H, :     >  a„2,  P-value  =  P(x'>Xo')  =  UTPC(v,Xo') 

.     H,:  a^^  P-value  =2.min[P(x^<Xo'),  P(x'>Xc')]  = 

2.min[l-UTPC(v,Xo'),  UTPC(v,Xo')] 

v/here  the  function  min[x,y]  produces  the  minimum  value  of  x  or  y  (similarly, 
max[x,y]  produces  the  maximum  value  of  x  or  y).  UTPC(v,x)  represents  the 
calculator's  upper-tail  probabilities  for  v  =  n  -  1  degrees  of  freedom. 

The  test  criteria  ore  the  same  as  in  hypothesis  testing  of  means,  namely, 

•  Reject      if  P-value  <  a 

•  Do  not  reject     if  P-value  >  a. 

Please  notice  that  this  procedure  is  valid  only  if  the  population  from  which  the 
sample  v/as  taken  is  a  Normal  population. 

Example  1  -  Consider  the  case  in  v/hich  =  25,  a=0.05,  n  =  25,  and  s^  = 
20,  and  the  sample  was  drawn  from  a  normal  population.  To  test  the 
hypothesis,  H^:  o^=  o^^  against  Hi:  a^<  a^^,  we  first  calculate 

2_(^-V_(25-l)-20_ 

al     ~       25  ~ 

With  V  =  n  -  1  =  25-1  =  24  degrees  of  freedom,  we  calculate  the  P-value  as, 

P-value  =  P(x'<19.2)  =  1-UTPC(24,19.2)  =  0.2587... 

Since,  0.2587...  >  0.05,  i.e.,  P-value  >  a,  we  cannot  reject  the  null 
hypothesis,  H^:  a^=25(=  a^^). 


Page  1 8-47 


Inferences  concerning  two  variances 

The  null  hypothesis  to  be  tested  is  ,  H^:  ai^=  q^,  at  o  level  of  confidence  (1- 
a)100%,  or  significance  level  a,  using  tv/o  samples  of  sizes,  ni  and  n2,  and 
variances  Si^  and  S2^.  The  test  statistic  to  be  used  is  an  F  test  statistic  defined 
as 


v/here  s^^  and  s^^  represent  the  numerator  and  denominator  of  the  F  statistic, 
respectively.  Selection  of  the  numerator  and  denominator  depends  on  the 
alternative  hypothesis  being  tested,  as  shown  below.  The  corresponding  F 
distribution  has  degrees  of  freedom,  =  n^-l,  and  =  no-l,  where  n^  and 
n^,  are  the  sample  sizes  corresponding  to  the  variances  s^^  and  Sd^, 
respectively. 


The  following  table  shows  how  to  select  the  numerator  and  denominator  for  F^, 
depending  on  the  alternative  hypothesis  chosen: 


Alternative 

Test 

Degrees 

hypothesis 

statistic 

of  freedom 

Hi:      <  a2^  (one-sided) 

Fo  =  S2Vsi^ 

Vn  =  n2-l,  Vd  =  ni-1 

H,:  ai^>  02^  (one-sided) 

Fo  =  siys2^^ 

Vn  =  ni-1,  Vd  =  n2-l 

Hi:  (ji^^G2^  (two-sided) 

Fq  —  SmV 

Vn  =  nM-l,VD  =  n^-1 

SM^=max(si^S2^),  s, 

„2=min(si^S22) 

(*)  n^  is  the  value  of  n 

corresponding  to  the  s^. 

and  n„  is  the  value  of  n 

corresponding  to  s^. 

The  P-value  is  calculated,  in  all  cases,  as:  P-value  =  P(F>FJ  =  UTPF(vn,  Vd,FJ 
The  test  criteria  are: 

•  Reject  Ho  if  P-value  <  a 

•  Do  not  reject  H^  if  P-value  >  a. 
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Examplel  -  Consider  two  samples  drawn  from  normal  populations  such  that 
H]  =  21,  n2  =  31,  S]^  =  0.36,  and  %2  =  0.25.  We  test  the  null  hypothesis,  H^: 
CTi^=      ,  at  a  significance  level  a  =  0.05,  against  the  alternative  hypothesis, 
H,:  oi^Ti  a2^.    For  a  two-sided  hypothesis,  we  need  to  identify  s^  and  s^,  as 
follows: 

SM^=max(si^,S2^)  =  max(0.36,0.25)  =  0.36  =  Si^ 
s„^=min{si^S2^)  =  min  (0.36,0.25)  =  0.25  =  S2^ 

Also, 

nM=  n,  =  21, 

=  "2  =  31, 

VN=nM- 1=21-1=20, 
Vd  =  n„-l  =  31-1  =30. 

Therefore,  the  F  test  statistics  is  F„  =  SmVs,„^=0. 36/0. 25=1 .44 

The  P-value  is  P-value  =  P(F>FJ  =  P(F>1.44)  =  UTPFK,  Vd,FJ  = 
UTPF(20,30,1.44)  =  0.1788... 

Since  0.1788...  >  0.05,  i.e.,  P-value  >  a,  therefore,  we  cannot  reject  the  null 
hypothesis  that  H^:  oi^  =  ■ 

Additional  notes  on  linear  regression 

in  this  section  we  elaborate  the  ideas  of  linear  regression  presented  earlier  in 
the  chapter  and  present  a  procedure  for  hypothesis  testing  of  regression 
parameters. 

The  method  of  least  squares 

Let  X  =  independent,  non-random  variable,  and  Y  =  dependent,  random 
variable.    The  regression  curve  of  Y  on  x  is  defined  as  the  relationship 
between  x  and  the  mean  of  the  corresponding  distribution  of  the  Y's. 
Assume  that  the  regression  curve  of  Y  on  x  is  linear,  i.e.,  mean  distribution  of 
Y's  is  given  by  A  -I-  Bx.    Y  differs  from  the  mean  (A  -I-  B-x)  by  a  value  e,  thus 
Y  =  A  -I-  B  x  -I-  E,  where  e  is  a  random  variable. 

To  visually  check  whether  the  data  follows  a  linear  trend,  draw  a  scattergram 
or  scatter  plot. 
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Suppose  that  we  have  n  paired  observations  (xi,  yj;  v/e  predict  y  by  means  of 
^y  =  a  +  b  x,  where  a  and  b  are  constant. 

Define  the  prediction  error  as,  e;  =  y;  -  ^y;  =  y;  -  (a  +  b-xj. 

The  method  of  least  squares  requires  us  to  choose  a,  b  so  as  to  minimize  the 
sum  of  squared  errors  (SSE) 


n  n 


SSE  =  Y,ef=^[y,-(a  +  bx,)f 

i=l  1=1 

the  conditions 

—  {SSE)  =  0  —(SSE)  =  0 
da  ^ 

We  get  the,  so-called,  normal  equations: 

n  n 
i=\  (=1 


i=\  i=\  i=\ 

This  is  a  system  of  linear  equations  with  a  and  b  as  the  unknowns,  which  can 
be  solved  using  the  linear  equation  features  of  the  calculator.  There  is, 
however,  no  need  to  bother  with  these  calculations  because  you  can  use  the 
3.  Fit  Data  ...  option  in  the  (.    J       menu  as  presented  earlier. 


Notes: 

•  a,b  are  unbiased  estimators  of  A,  B. 

•  The  Gauss-Markov  theorem  of  probability  indicates  that  among  all 
unbiased  estimators  for  A  and  B,  the  least-square  estimators  (a,b)  are  the 
most  efficient. 
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Additional  equations  for  linear  regression 

The  summary  statistics  such  as  Ex,  2x^,  etc.,  can  be  used  to  define  the 
following  quantities: 

n 

1=1 

i=\ 

i=l 

From  which  it  follows  that  the  standard  deviations  of  x  and  y,  and  the 
covariance  of  x,y  are  given,  respectively,  by 

=  '      =  J— ^'Ond  s  =^ 

\n-l  \n-l  n-l 


n  1  I  " 

=  (n-\)-sl  =J^x'  —  ^x, 


;=i 


«  V  '=1  . 


,=1  n  \  ,=1  y 


s 

Also,  the  sample  correlation  coefficient  isr^^  =  , 

^|^^  -^yy 


In  terms  of  x,  y,  S^x,  Syy,  and  S^y,  the  solution  to  the  normal  equations  is: 


a  =  y  -bx  , 


Prediction  error 

The  regression  curve  of  Y  on  x  is  defined  as  Y  =  A  +  B-x  +  s.  If  we  have  a  set 
of  n  data  points  (x,,  yj,  then  we  can  write  Yj  =  A  +  B-Xj  +  E|,  (i  =  l,2,...,n), 
where  Y|  =  independent,  normally  distributed  random  variables  with  mean 
(A  +  B  xj)  and  the  common  variance  a^;  Sj  =  independent,  normally  distributed 
random  variables  with  mean  zero  and  the  common  variance  a^. 
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Let  Yi  =  actual  data  value,  "yi  =  a  +  b  x|=  least-square  prediction  of  the  dote. 
Then,  the  prediction  error  is:  ei  =  yi  -  "yi  =  yi  -  (o  +  b  xj). 

An  estimate  of     is  the,  so-called,  standard  error  of  the  estimate, 

n  —  2~~{  n  —  2  n  —  2 

Confidence  intervals  and  hypothesis  testing  in  linear  regression 

Here  are  some  concepts  and  equations  related  to  statistical  inference  for 
linear  regression: 

•  Confidence  limits  for  regression  coefficients: 

For  the  slope  (B):         b  -  (t  n.2,a/2)-Se/VS,,  <   B  <    b  +  (\  „.2,a/2)-Se/VS,„ 

For  the  intercept  (A): 

a-(t„.2,a/2)-Se-[{l/n)+  xYSJ^^^  <  A  <  o  +  (t  „.2,„/2)-s,-[(  1 /n)+  xVSJi/^ 
where  t  follows  the  Student's  t  distribution  with  v  =  n  -  2,  degrees  of 
freedom,  and  n  represents  the  number  of  points  in  the  sample. 

•  Hypothesis  testing  on  the  slope,  B: 

Null  hypothesis,  HqI  B  =  Bq,  tested  against  the  alternative  hypothesis,  H^: 
B  ^  Bq.  The  test  statistic  is  tg  =  (b  ■Bq)/(sJ^S^^),  where  t  follows  the 
Student's  t  distribution  with  v  =  n  -  2,  degrees  of  freedom,  and  n 
represents  the  number  of  points  in  the  sample.  The  test  is  carried  out  as 
that  of  a  mean  value  hypothesis  testing,  i.e.,  given  the  level  of 
significance,  a,  determine  the  critical  value  of  t,  t„/2/  then,  reject  Hg  if  tg  > 
t„/2  or  if  tg  <  - 1„/2. 

If  you  test  for  the  value  Bo=  0,  and  it  turns  out  that  the  test  suggests  that 
you  do  not  reject  the  null  hypothesis,  Hg:  B  =  0,  then,  the  validity  of  a 
linear  regression  is  in  doubt.  In  other  words,  the  sample  data  does  not 
support  the  assertion  that  B  0.  Therefore,  this  is  a  test  of  the 
significance  of  the  regression  model. 
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•  Hypothesis  testing  on  the  intercept ,  A: 

Null  hypothesis,  Hq:  A  =  Aq,  tested  against  the  alternative  hypothesis,  H,: 
A  ^  Aq.  The  test  statistic  is  to  =  (a-Ao)/[(l/n)+  xVSJ^^^/  where  t  follows 
the  Student's  t  distribution  with  v  =  n  -  2,  degrees  of  freedom,  and  n 
represents  the  number  of  points  in  the  sample.  The  test  is  carried  out  as 
that  of  a  mean  value  hypothesis  testing,  i.e.,  given  the  level  of 
significance,  a,  determine  the  critical  value  of  t,  tci/2,  then,  reject  Hq  if  tg  > 
t„/2  or  if  to  <  - 1„/2. 

•  Confidence  interval  for  the  mean  value  of  Y  at  x  =  Xo,  i.e.,  a+|3xo: 
a+b-x-(t  n-2,a/2)-Se-[(l/n)+{xo-  x)VSJ^/^  <  a+pxo< 

a+b-x+(t  „.2,a/2)-Se-[(l/n)+(xo-  xjVSJ^/l 

•  Limits  of  prediction:  confidence  interval  for  the  predicted  value  Yo=Y(xo): 

a+b.x-(t  ..2,a/2)-Se-[l+(l/n)+(xo-  AV^J'^  <  Yq < 

a+b-x+(t  „.2,  a  /2)-Se-[  1  +( 1  /n)+(xo-  x) VS  J 

Procedure  for  inference  statistics  for  linear  regression  using  the 
calculator 

1 )  Enter  (x,y)  as  columns  of  data  in  the  statistical  matrix  ZDAT. 

2)  Produce  a  scatterplot  for  the  appropriate  columns  of  EDAT,  and  use 
appropriate  H-  and  V-VIEWS  to  check  linear  trend. 

3)  Use  C3  °:!°!:°.!T:!,   to  fit  straight  line,  and  get  a,   b,  s^^ 
(Covariance),  and  r^y  (Correlation). 

4)  Use  [    J  _snr       yjj^jliijj,    to  obtain   x,  y,  s^,  Sy.  Column  1  v^ill  show  the 
statistics  for  x  while  column  2  will  show  the  statistics  for  y. 

5)  Calculate 

n-2 

6)  For  either  confidence  intervals  or  two-tailed  tests,  obtain  t„/2,  with  (1- 
a)100%  confidence,  from  t-distribution  with  v  =  n  -2. 

7)  For  one-  or  two-tailed  tests,  find  the  value  of  t  using  the  appropriate 
equation  for  either  A  or  B.  Reject  the  null  hypothesis  if  p-value  <  a. 

8)  For  confidence  intervals  use  the  appropriate  formulas  as  shown  above. 
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Example  1  -  For  the  following  (x,y)  data,  determine  the  95%  confidence 
interval  for  the  slope  B  and  the  intercept  A 


X    2.0      2.5      3.0      3.5  4.0 


y    5.5      7.2      9.4     10.0  12.2 


Enter  the  (x,y)  data  in  columns  1  and  2  of  EDAT,  respectively.  A  scatterplot  of 
the  data  shows  a  good  linear  trend: 


These  results  ore  interpreted  as  a  =  -0.86,  b  =  3.24,  r,y  =  0.989720229749, 
and  s^y  =  2.025.  The  correlation  coefficient  is  close  enough  to  1 .0  to  confirm 
the  linear  trend  observed  in  the  graph. 

From  the  single-var...  option  of  the  (j^l  stat  menu  we  find:  x  =  3,  s^  = 
0.790569415042,  y  =  8.86,  s^  =  2.58804945857. 

Next,  with  n  =  5,  calculate 


Use  the  Fit  Data. .  option  in  the  [  r»  J  stat  menu,  to  get: 


3 
2 
1 


'-.86  +  3.24*X' 
Correlation:  0.989720229749 
Covariance :  2.025 


S^=(n-\)-  si  =  (5  - 1)  •  0.790569415042'  =  2.5 


n-\ 


n-2 


5-1 


•  2.5880...'  •  (1  - 0.9897...')  =  0.1826... 


5-2 
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Confidence  intervals  for  tfie  slope  (B)  and  intercept  (A): 

•  First,  we  obtain  t  n.2,a/2  =  ^3,0.025  =  3.1 8244630528  (See  cfiapter  1 7  for  a 
program  to  solve  for  ty^,): 

•  Next,  we  calculate  tfie  terms 

(t  „.2,a/2)-Se/VS,,  =  3 . 1 82 . . . -(0. 1 826. . ./2 .Sj^^^  ^  0.8602... 

(t  „-2,a/2)-Se-[(l/n)+   xVSJ^''^  = 

3.1824...-V0.1826...[(l/5)+3V2.5]i/2  =  2.65 

•  Finally,  for  the  slope  B,  the  95%  confidence  interval  is 

(-0.86-0.860242,  -0.86+0.860242)  =  (-1.72,  -0.00024217) 

For  the  intercept  A,  the  95%  confidence  interval  is  (3.24-2.6514, 
3.24+2.6514)  =  (0.58855,5.8914). 

Example  2  ~  Suppose  that  the  y-data  used  in  Example  1  represent  the 
elongation  (in  hundredths  of  an  inch)  of  a  metal  wire  when  subjected  to  a 
force  X  (in  tens  of  pounds).  The  physical  phenomenon  is  such  that  we  expect 
the  intercept,  A,  to  be  zero.  To  check  if  that  should  be  the  case,  we  test  the 
null  hypothesis,  Hq:  A  =  0,  against  the  alternative  hypothesis,  H,;  A  0,  at  the 
level  of  significance  a  =  0.05. 

The  test  statistic  is  to  =  (a-0)/[(l/n)+  xVSJ'/2=  (-0.86)/  [(l/5)+3V2.5] '''^  =  - 
0.441 17.  The  critical  value  of  t,  for  v  =  n  -  2  =  3,  and  a/2  =  0.025,  can 
be  calculated  using  the  numerical  solver  for  the  equation  a  =  UTPT(y,t) 
developed  in  Chapter  17.  In  this  program,  y  represents  the  degrees  of 
freedom  (n-2),  and  a  represents  the  probability  of  exceeding  a  certain  value 
of  t,  i.e.,  Pr[  t>tj  =  1  -  a.  For  the  present  example,  the  value  of  the  level  of 
significance  is  a  =  0.05,  g  =  3,  and  tn2,a/2  =  *3,o.o25-  Also,  for  y  =  3  and  a  = 
0.025,  tn.2,a/2  =  ^3,0.025  =  3.18244630528.  Because  to  >  ■  t„.2,a/2/  we  cannot 
reject  the  null  hypothesis,  Hq:  A  =  0,  against  the  alternative  hypothesis.  Hi:  A 
^  0,  at  the  level  of  significance  a  =  0.05. 

This  result  suggests  that  taking  A  =  0  for  this  linear  regression  should  be 
acceptable.  After  all,  the  value  we  found  for  a,  was  -0.86,  which  is  relatively 
close  to  zero. 
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Example  3  -  Test  of  significance  for  the  linear  regression.  Test  the  null 
hypothesis  for  the  slope  Hg:  B  =  0,  against  the  alternative  hypothesis,  Hi:  B  5^ 
0,  at  the  level  of  significance  a  =  0.05,  for  the  linear  fitting  of  Example  1 . 

The  test  statistic  is  to  =  (b  -BoVisJ^SJ  =  (3.24-0)/(Vo.l  8266666667/2.5)  = 
18.95.  The  critical  value  of  t,  for  v  =  n  -  2  =  3,  and  a/2  =  0.025,  v/as 
obtained  in  Example  2,  as  t„.2,a/2  =  h.oms  = 

3.18244630528.  Because,  to  > 
ta/2,  we  must  reject  the  null  hypothesis  H^:  B  ^  0,  a\  the  level  of  significance  a 
=  0.05,  for  the  linear  fitting  of  Example  1 . 

Multiple  linear  fitting 

Consider  a  data  set  of  the  form 


X3  . 

••  Xn 

y 

Xll 

X21 

X3I 

X„i 

Xl2 

X22 

X32 

X„2 

y2 

Xl3 

X32 

X33 

X„3 

ys 

Xl,m-1 

X  2,m-l 

X  3,m-l 

X  „ 

Ym-l 

Xl.m 

X  2.m 

X  3.m 

^  n,m 

Vm 

Suppose  that  we  search  for  a  data  fitting  of  the  form  y  =  bo  +  byXi  +  b2-X2  + 
bs-Xs  +  ...  +  bn-Xn.  You  can  obtain  the  least-square  approximation  to  the 
values  of  the  coefficients  b  =  [bo   bi  b2  ba  ...  bj,  by  putting  together  the 
matrix  X: 


1 

Xll 

X2I 

X3I 

Xnl 

1 

X12 

X22 

X32 

X„2 

1 

Xl3 

X32 

X33 

X„3 

1 

Xl,m 

X  2,m 

X  3,m 

X  n. 
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Then,  the  vector  of  coefficients  is  obtained  from  b  =  (X^-X)^ -X^-y,  where  y  is 
the  vector  y  =  [y,     ...  yj\ 

For  example,  use  the  follov/ing  data  to  obtain  the  multiple  linear  fitting 


y  =  bo 

+  bi-Xi 

+  b2-X2  + 

X2 

X3 

y 

1.20 

3.10 

2.00 

5.70 

2.50 

3.10 

2.50 

8.20 

3.50 

4.50 

2.50 

5.00 

4.00 

4.50 

3.00 

8.20 

6.00 

5.00 

3.50 

9.50 

With  the  calculator,  in  RPN  mode,  you  can  proceed  as  follows: 

First,  within  your  HOME  directory,  create  a  sub-directory  to  be  called  MPFIT 
(Multiple  linear  and  Polynomial  data  FITting) ,  and  enter  the  MPFIT  sub- 
directory.  Within  the  sub-directory,  type  this  program: 

^  X  y  -^K  X  TRAN  X  *   INV  X  TRAN  *  y  *  S-  ;S- 

and  store  it  in  a  variable  called  MTREG  (MulTiple  REGression). 

Next,  enter  the  matrices  X  and  b  into  the  stack: 

[[1,1. 2,3. 1,2][1,2.5,3. 1,2.5  ][1,3.5,4.5,2.5][1,4,4.5,3][1,6,5,3.5]] 

lENTERjiENTEK)  (keep  On  extra  copy) 

[5.7,8.2,5.0,8.2,9.5] 

Press  CW3EIES]].  The  result  is:  [-2. 1649.. .,-0.7144...,-]  .7850.. .,7.0941 ...], 
i.e., 

y  =  -2.1649-0.7144  x1  -1 .7850x1  O^-Xj  +  7.0941  Xj  . 
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You  should  hove  in  your  calculator's  stack  the  value  of  the  matrix  X  and  the 
vector  b,  the  fitted  values  of  y  are  obtained  from  y  =  X  b,  thus,  just  press  I  x  J 
to  obtain:  [5.63..,  8.25..,  5.03..,  8.23..,  9.45..]. 

Compare  these  fitted  values  v/ith  the  original  data  as  shov/n  in  the  table 
below: 


X2 

X3 

y 

y-fitted 

1.20 

3.10 

2.00 

5.70 

5.63 

2.50 

3.10 

2.50 

8.20 

8.25 

3.50 

4.50 

2.50 

5.00 

5.03 

4.00 

4.50 

3.00 

8.20 

8.23 

6.00 

5.00 

3.50 

9.50 

9.45 

Polynomial  fitting 

Consider  the  x-y  data  set  {(xi,yi),  (x2,y2),      (Xn,yn)}.   Suppose  that  we  want 
to  fit  a  polynomial  or  order  p  to  this  data  set.  In  other  words,  we  seek  a  fitting 
of  the  form  y  =  bo  +  bi-x  +  b2-x^  +  b^-x-^  +  ...  +  bp-x^.   You  can  obtain  the 
least-square  approximation  to  the  values  of  the  coefficients  b  =  [bo   bi  b2 
ba  ...  bp],  by  putting  together  the  matrix  X 


1 

Xl 

Xl^ 

X  3 
Xl 

y/ 

1 

X2 

X2^ 

X2 

• 

y2'' 

1 

X3 

X3 

V  3 
X3 

y3'' 

1 

x„ 

X  2 

X  3 

X  P"^ 

yn'' 

Then,  the  vector  of  coefficients  is  obtained  from  b  =  (X^-X)^ -X^-y,  where  y  is 
the  vector  y  =  [yi  y2  ...  yn]^. 

In  Chapter  10,  we  defined  the  Vandermonde  matrix  corresponding  to  a 
vector  X  =  [xi  X2  ...  x^]  .  The  Vandermonde  matrix  is  similar  to  the  matrix  X 
of  interest  to  the  polynomial  fitting,  but  having  only  n,  rather  than  (p+1) 
columns. 

We  can  take  advantage  of  the  VANDERMONDE  function  to  create  the  matrix 
X  if  we  observe  the  following  rules: 
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Ifp  =  n-?,X  =  V„. 

If  p  <  n-1,  then  remove  columns  p+2,       n-1,  n  from       to  form  X. 
If  p  >  n-1,  then  odd  columns  n+1,       p-1,  p+1,  to      to  form  matrix  X. 

In  step  3  from  this  list,  we  have  to  be  aware  that  column  /  (/=  n+1,  n+2, 
p+1)  is  the  vector  [x,  X2'  ...  x„'].    If  we  were  to  use  a  list  of  data  values  for  x 
rather  than  a  vector,  i.e.,  x  =  {  x,  X2  ...  x^ },  we  can  easily  calculate  the 
sequence  {  x/  Xj'  ...  x„'  }.  Then,  we  con  transform  this  list  into  a  vector  and 
use  the  COL  menu  to  add  those  columns  to  the  matrix     until  X  is  completed. 

After  X  is  ready,  and  having  the  vector  y  available,  the  calculation  of  the 
coefficient  vector  b  is  the  same  as  in  multiple  linear  fitting  (the  previous  matrix 
application).  Thus,  we  can  write  a  program  to  calculate  the  polynomial  fitting 
that  can  take  advantage  of  the  program  already  developed  for  multiple  linear 
fitting.  We  need  to  add  to  this  program  the  steps  1  through  3  listed  above. 

The  algorithm  for  the  program,  therefore,  can  be  written  as  follows: 

Enter  vectors  x  and  y,  of  the  same  dimension,  as  lists.    (Note:  since  the 
function  VANDERMONDE  uses  a  list  as  input,  it  is  more  convenient  to  enter 
the  (x,y)  data  as  a  list.)  Also,  enter  the  value  of  p. 

•  Determine  n  =  size  of  vector  x. 

•  Use  the  function  VANDERMONDE  to  generate  the  Vandermonde 
matrix  V„  for  the  list  x  entered. 

•  If  p  =  fj-7,  then 

x  =  v„. 

Else  If  p  <  n-1 

Remove  columns  p+2,       n  from  V„  to  form  X 
(Use  a  FOR  loop  and  COL-) 

Else 

Add  columns  n+1,  .. .,  p+ 1  to  V„  to  form  X 

(FOR  loop,  calculate  x',  convert  to  vector,  use  COL+) 

•  Convert  y  to  vector 

•  Calculate  b  using  program  MTREG  (see  example  on  multiple  linear 
fitting  above) 
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Here  is  the  translafion  of  the  algorithm  to  a  program  in  User  RPL  language. 
(See  Chapter  21  for  additional  information  on  programming): 


^  xy  p 
X  SIZE  ^  n 

■S 

X  VANDERMONDE 
IF  'p<n-l'THEN 

n 

p2  + 
FORj 

j  COL- DROP 
-1  STEP 
ELSE 
IF'p>n-l'THEN 
n  1  + 
pi  + 
FOR  i 
X  j 

OBJ^  ^ARRY 
j  COL+ 
NEXT 
END 
END 

y  OBJ^  ^ARRY 

MTREG 

^NUM 


Open  program 

Enter  lists  x  and  y,  and  p  (levels  3,2,1) 

Open  subprogram  1 

Determine  size  of  x  list 

Open  subprogram  2 

Place  X  in  stack,  obtain 

This  IF  implements  step  3  in  algorithm 

Place  n  in  stack 

Calculate  p+1 

Start  loop  j  =  n-1 ,  n-2,      p+1 ,  step  =  ■ 
Remove  column  and  drop  it  from  stack 
Close  FOR-STEP  loop 


Calculate  n+1 
Calculate  p+1 

Start  a  loop  with  j  =  n,  n+1 ,      p+1 . 

Calculate  x',  as  a  list 

Convert  list  to  array 

Add  column  to  matrix 

Close  FOR-NEXT  loop 

Ends  second  IF  clause. 

Ends  first  IF  clause.  Its  result  is  X 

Convert  list  y  to  an  array 

X  and  y  used  by  program  MTREG 

Convert  to  decimal  format 

Close  sub-program  2 

Close  sub-program  1 

Close  main  program 


1 


Save  it  into  a  variable  called  POLY  (POLYnomial  fitting). 
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As  an  example,  use  the  following  data  to  obtain  a  polynomial  fitting  withi  p  = 
2,  3,  4,  5,  6.   


X 

y 

2.30 

179.72 

3.20 

562.30 

4.50 

1969.11 

1.65 

65.87 

9.32 

31220.89 

1.18 

32.81 

6.24 

6731.48 

3.45 

737.41 

9.89 

39248.46 

1.22 

33.45 

Because  we  will  be  using  the  same  x-y  data  for  fitting  polynomials  of  different 
orders,  it  is  advisable  to  save  the  lists  of  data  values  x  and  y  into  variables  xx 
and  yy,  respectively.  This  way,  we  will  not  have  to  type  them  all  over  again 
in  each  application  of  the  program  POLY.  Thus,  proceed  as  follows: 

{  2.3  3.2  4.5  1.65  9.32  1.18  6.24  3.45  9.89  1.22  }S  'xx'  [s^ 
{179.72  562.30  1969.11  65.87  31220.89  32.81  6731.48  737.41 
39248.46  33.45}  'yy' 

To  fit  the  data  to  polynomials  use  the  following: 

!ES3S  KSB  2  IGEBBI,  Result:  [4527.73  -3958.52  742.23] 

i.e.,  y  =  4527.73-39.58x+742.23x' 

ISSl  igss  3  IGEI^EI,  Result:  [-998.05  1303.21  -505.27  79.23] 

i.e.,  y  =  -998.05+1 303.21 x-505.27x'+79.23x' 

!ES3S  KSa  4  IGEBBI,  Result:  [20.92  -2.61  -1.52  6.05  3.51  ] 

i.e.,  y  =  20.92-2.61 x-1.52x'+6.05x'+3.51x^. 

ilgSil  sm  5  mm,  Result:  [19.08  0.18-2.94  6.36  3.48  0.00  ] 

i.e.,  y=  1 9.08+0.1 8x-2.94x^-i-6.36x^+3.48xU0.00nx^ 

iESSS  SSm  6  GEffii,  Result:  [-16.73  67.17-48.69  21.11  1.07  0.19  0.00] 

i.e.,     y  =  -16.73+67. 17x-48.69x^+21. 1 1x^+1 .07xU0.19x^+0.0058x^ 
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Selecting  the  best  fitting 

As  you  can  see  from  the  results  above,  you  can  fit  any  polynomial  to  a  set  of 
data.  Tfie  question  arises,  wfiich  is  the  best  fitting  for  the  data?  To  help  one 
decide  on  the  best  fitting  we  can  use  several  criteria: 

•  The  correlation  coefficient,  r.  This  value  is  constrained  to  the  range  - 
1  <  r  <  1 .  The  closer  r  is  to  +1  or  -1 ,  the  better  the  data  fitting. 

•  The  sum  of  squared  errors,  SSE.  This  is  the  quantity  that  is  to  be 
minimized  by  least-square  approach. 

•  A  plot  of  residuals.   This  is  a  plot  of  the  error  corresponding  to  each 
of  the  original  data  points.  If  these  errors  are  completely  random,  the 
residuals  plot  should  show  no  particular  trend. 

Before  attempting  to  program  these  criteria,  we  present  some  definitions: 

Given  the  vectors  x  and  y  of  data  to  be  fit  to  the  polynomial  equation,  we 
form  the  matrix  X  and  use  it  to  calculate  a  vector  of  polynomial  coefficients  b. 
We  can  calculate  a  vector  of  fitted  data,  y',  by  using  y'  =  X-b. 

An  error  vector  is  calculated  by  e  =  y  -  y'. 

The  sum  of  square  errors  is  equal  to  the  square  of  the  magnitude  of  the  error 
vector,  i.e.,  SSE  =  |  e  |  ^  =  e.e  =  S  6;^  =  S  (yi-y'i)l 

To  calculate  the  correlation  coefficient  we  need  to  calculate  first  what  is 
known  as  the  sum  of  squared  totals,  SST,  defined  as  SST  =  E  (y,-  y)^,  where  y 
is  the  mean  value  of  the  original  y  values,  i.e.,  y  =  (Syi)/n. 

In  terms  of  SSE  and  SST,  the  correlation  coefficient  is  defined  by 

r=  [1-(SSE/SST)]  . 

Here  is  the  new  program  including  calculation  of  SSE  and  r  (Once  more, 
consult  the  last  page  of  this  chapter  to  see  how  to  produce  the  variable  and 
command  names  in  the  program): 
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^  xy  p 

X  SIZE  ^  n 

X  VANDERMONDE 
IF  'p<n-l'THEN 
n 

p2  + 
FOR  i 

j  COL- DROP 
■1  STEP 
ELSE 
IF'p>n-l'THEN 
n  1  + 
pi  + 
FOR  i 
X  j 

OBJ^  ^ARRY 
i  COL+ 
NEXT 
END 
END 

y  OBJ^  ^ARRY 
^    X  yv 

X   yv  MTREG 

^NUM 

^  b 

b  yv 
Xb  * 

ABS  SQDUP 

y  ZLISTn/ 

n  1  ^LIST  SWAP  CON 


Open  program 

Enter  lists  x  and  y,  and  number  p 
Open  subprogram! 
Determine  size  of  x  list 
Open  subprogram  2 
Place  X  in  stack,  obtain 
This  IF  is  step  3  in  algorithm 
Place  n  in  stack 
Calculate  p+1 

Start  loop,  j  =  n-1  to  p+1,  step  =  -1 
Remove  column,  drop  from  stack 
Close  FOR-STEP  loop 

Calculate  n+1 
Calculate  p+1 

Start  loop  v/ith  j  =  n,  n+1 ,      p+1 . 

Calculate  x',  as  a  list 

Convert  list  to  array 

Add  column  to  matrix 

Close  FOR-NEXT  loop 

Ends  second  IF  clause. 

Ends  first  IF  clause.  Produces  X 

Convert  list  y  to  an  array 

Enter  matrix  and  array  as  X  and  y 

Open  subprogram  3 

X  and  y  used  by  program  MTREG 

If  needed,  converts  to  floating  point 

Resulting  vector  passed  as  b 

Open  subprogram  4 

Place  b  and  yv  in  stack 

Calculate  X-b 

Calculate  e  =  y  -  X-b 

Calculate  SSE,  make  copy 

Calculate  y 

Create  vector  of  n  values  of  y 
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yv  -  ABS  SQ  Calculate  SST 

/  Calculate  SSE/SST 

NEG  1  +  V  Calculate  r  =  [1 -SSE/SST 

"r"  ^TAG  Tag  result  as  "r" 

SWAP  Exchange  stack  levels  1  and  2 

"SSE"  ^TAG  Tag  result  as  SSE 

Close  sub-program  4 
Close  sub-program  3 
Close  sub-program  2 
Close  sub-program  1 
Close  main  program 


Save  this  program  under  the  name  POLYR,  to  emphasize  calculation  of  the 
correlation  coefficient  r. 


Using  the  POLYR  program  for  values  of  p  betv/een  2  and  6  produce  the 
follov^ing  table  of  values  of  the  correlation  coefficient,  r,  and  the  sum  of 
square  errors,  SSE: 


p 

r 

SSE 

2 

0.9971908 

10731140.01 

3 

0.9999768 

88619.36 

4 

0.9999999 

7.48 

5 

0.9999999 

8.92 

6 

0.9999998 

432.61 

While  the  correlation  coefficient  is  very  close  to  1 .0  for  all  values  of  p  in  the 
table,  the  values  of  SSE  vary  widely.  The  smallest  value  of  SSE  corresponds  to 
p  =  4.  Thus,  you  could  select  the  preferred  polynomial  data  fitting  for  the 
original  x-y  data  as: 


y  =  20.92-2.61 x-1.52x'+6.05x^+3.51>^. 
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Chapter  19 

Numbers  in  Different  Bases 

In  this  Chapter  we  present  examples  of  calculations  of  number  in  bases  other 
than  the  decimal  basis. 

Definitions 

The  number  system  used  for  everyday  arithmetic  is  known  as  the  decimal 
system  for  it  uses  10  (Latin,  deca)  digits,  namely  0-9,  to  write  out  any  real 
number.  Computers,  on  the  other  hand,  use  a  system  that  is  based  on  two 
possible  states,  or  binary  system.  These  two  states  ore  represented  by  0  and 
1,  ON  and  OFF,  or  high-voltage  and  low-voltage.  Computers  also  use 
number  systems  based  on  eight  digits  (0-7)  or  octal  system,  and  sixteen  digits 
(0-9,  A-F)  or  hexadecimal.  As  in  the  decimal  system,  the  relative  position  of 
digits  determines  its  value.  In  general,  a  number  n  in  base  b  can  be  written 
as  a  series  of  digits  n  =  (0102  ...an.CiC2  ...cJb.  The  "point"  separates  n 
"integer"  digits  from  m  "decimal"  digits.  The  value  of  the  number,  converted 
to  our  customary  decimal  system,  is  calculated  by  using  n  =  a,-bn  '  +  Oj-fa"^ 
+  ...  +  a„b°  +  cyb^  +  C2-b^  +  ...  +c„-b"'.  For  example,  (15.234)io  =  MO'  + 
5-10°  +  2-10'  -I-  3-10-2  -I-  4-10^  and  (101.111)2  =  1-2^  -1-  0-2'  -1-  1-2°  -1- 
1  -2'  +  1  -2-2  -1-  1  -2-3 

The  BASE  menu 

while  the  calculator  would  typically  be  operated  using  the  decimal  system, 
you  can  produce  calculations  using  the  binary,  octal,  or  hexadecimal  system. 
Many  of  the  functions  for  manipulating  number  systems  other  than  the  decimal 
system  are  available  in  the  BASE  menu,  accessible  through  [  r»  J  (the  (.  3  J 
key).  With  system  flag  1 1 7  set  to  CHOOSE  boxes,  the  BASE  menu  shows 
the  following  entries: 


SflSE  HEnu 

3.0CT  K 

H.Ein  K 

5.R-* 

1       1       1  IcflncL 

OK 

EHfE  HEnu 

?. LOGIC. 

g.EIT.. 

S.EVTE.. 

10.  £TH£ 

11.  RCHS  1 

narmr^^^^Hl 

ICHRCL 

OK 
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With  system  flag  1 1 7  set  to  SOFT  menus,  the  BASE  menu  shows  the  following: 


With  this  format,  it  is  evident  that  the  LOGIC,  BIT,  and  BYTE  entries  within  the 
BASE  menu  are  themselves  sub-menus.  These  menus  are  discussed  later  in  this 
Chapter. 


Functions  HEX,  DEC,  OCT,  and  BIN 

Numbers  in  non-decimal  systems  are  written  preceded  by  the  #  symbol  in  the 

calculator.   The  symbol  #  is  readily  available  as  I  <~i  }*  (the  3  key).  To 

select  which  number  system  (current  base)  will  be  used  for  numbers  preceded 

by  #,  select  one  of  the  following  functions  in  the  first  BASE  menu,  i.e.. 


11  IS 


HEX(adecimal),  DEC(imal),  OCT(al),  or  BIN(ary).  For  example,  if  IL 
selected,  any  number  written  in  the  calculator  that  starts  with  #  will  be  a 
hexadecimal  number.  Thus,  you  can  write  numbers  such  as  #53,  #A5B,  etc. 
in  this  system.  As  different  systems  are  selected,  the  numbers  will  be 
automatically  converted  to  the  new  current  base. 


The  following  examples  show  the  same  three  numbers  written  with  the  # 
symbol  for  different  current  bases: 


HEX 

:  # 

R£F0hi 

#  R2F0ti 

:  # 

2EC10hi 

#  2EC10ti 

:  # 

125hi 

#  125ti 

DEC 


#  41712d 

#  17921&d 

#  293d 


#  41712d 
#  179216d 


#  293d 


OCT 


#  121360O 

#  536020O 

#  445o 


#  1213600 

#  5360200 


#  4450 


BIN 


#  1010001011110000b  I 
#  1010001011110000b 

^  101011110000010000b 
#  101011110000010000b 

#  100100101b 

#  100100101b 
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As  the  decimal  (DEC)  system  has  10  digits  (0,1,2,3,4,5,6,7,8,9),  the 
hexadecimal  (HEX)  system  has  16  digits  (0,1,2,3,4,5,6,7,8,9,A,B,C,D,E,F), 
the  octal  (OCT)  system  has  8  digits  (0,1,2,3,4,5,6,7),  and  the  binary  (BIN) 
system  has  only  2  digits  (0,1). 


Conversion  between  number  systems 

Whatever  the  number  system  selected,  it  is  referred  to  as  the  binary  system  for 
the  purpose  of  using  the  functions  R^B  and  B^R.  For  example,  if  ^^Mm\  is 
selected,  the  function  B^R  will  convert  any  hexadecimal  number  (preceded 
by  #)  into  a  decimal  number,  while  the  function  R^B  works  in  the  opposite 
direction.  Try  the  following  exercises,  HEX  is  the  current  base: 


165. 


,  4S77  . 


R-*B(1425S) 
R-*B(7S4) 


#  37E2ti 


,  #  310ti 


The  following  examples  show  conversions  when  the  base  is  the  octal  system; 


B^R<#  4752o> 
E->Rt#  7777o> 


2533, 


,  4095 


R-*B(453) 
R->E(127S9) 


#  712o 


,  #  307650 


We  also  present  transformations  using  the  binary  system  as  the  current  base: 


B-*Rt#  110110001b> 

433 

B-*Rt#  110110110110b> 
3510 

B-*Rt#  1110001110001M 
,  7231 


:  R-*E(4£) 
R-*E(524) 
R-*B(S41) 


#  101010b 
#  1000001100b 


#  1101001001b 


Notice  that  every  time  you  enter  a  number  starting  with  #,  you  get  as  the  entry 
the  number  you  entered  preceded  by  #  and  followed  by  the  letter  h,  o,  or  b 
(hexadecimal,  octal,  or  binary).  The  type  of  letter  used  as  suffix  depends  on 
which  non-decimal  number  system  has  been  selected,  i.e.,  HEX,  OCT,  or  BIN. 
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To  see  what  happens  if  you  select  the  lEiiBI  setting,  try  the  following 
conversions: 


:  B-*Rt#  69Sd>  :R-*B(147) 

693.  #  147d 

:   B-*Rt#  257d>  :R-*B(7S5) 

 257.   #  7S5d 

The  only  effect  of  selecting  the  DECimal  system  is  that  decimal  numbers,  when 
started  with  the  symbol  #,  are  written  with  the  suffix  d. 

Wordsize 

The  wordsize  is  the  number  of  bits  in  a  binary  object.  By  default,  the 
wordsize  is  64  bites.  Function  RCWS  (ReCall  WordSize)  shows  the  current 
wordsize.  Function  STWS  (SeT  the  WordSize)  allows  the  user  to  reset  the 
wordsize  to  any  number  between  0  and  64. 

Changing  the  wordsize  will  affect  the  way  that  binary  integer  operations  are 
performed.  For  example,  if  a  binary  integer  exceeds  the  current  wordsize,  the 
leading  bits  will  be  dropped  before  any  operation  can  be  performed  on  such 
number. 

Operations  with  binary  integers 

The  operations  of  addition,  subtraction,  change  of  sign,  multiplication,  and 
division  are  defined  for  binary  integers.  Some  examples,  of  addition  and 
subtraction,  are  shown  below,  for  different  current  bases: 


■LL  •■  r:i  t-ii  r:i  •!  4  i~j  4  -e  i'-Ii  i~j  rii  i_ 

■It  .L  tuLiti  1  J.  ^:J  J.  1  i;.ii::ji;.iu 
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The  LOGIC  menu 

The  LOGIC  menu,  available  through  the  BASE  (I  r>  }_Mse)  provides  the 
follov/ing  functions: 


SflSE  HEnu 

?. LOGIC. 

g.EIT.. 

S.EYTE.. 

10.£TH£ 

ll.RCHf  1 

1       1       1  IcflncL 

OK 

LOGIC  HEnu 

1  Ann 

2.  OR 

3.  K0R 
H.nOT 
S.SflSE.. 

1         1  1 

icnncLl 

OK 

The  functions  AND,  OR,  XOR  (exclusive  OR),  and  NOT  are  logical  functions. 
The  input  to  these  functions  are  two  values  or  expressions  (one  in  the  case  of 
NOT)  that  can  be  expressed  as  binary  logical  results,  i.e.,  0  or  1 . 
Comparisons  of  numbers  through  the  comparison  operators  =,  j^,  >,  <,  <,  and 
>,  are  logical  statements  that  can  be  either  true  (1)  or  false  (0).  Some 


: 5==3+2 

1 

1 

:2*2 

0 

:5>2 

1 

Functions  AND,  OR,  XOR,  and  NOT  can  be  applied  to  comparison  statements 
under  the  following  rules: 


1  AND  1  =  1 

1  AND  0  =  0 

0  AND  1  =  0 

0  AND  0  =  0 

1  OR  1  =  1 

1  OR  0=1 

0  OR  1  =  1 

0  OR  0  =  0 

1  XOR  1  =  0 

1  XOR  0  =  1 

0  XOR  1  =  1 

0  XOR  0  =  0 

NOT(l)  =  0 

NOT(O)  =  1 

These  functions  can  be  used  to  build  logical  statements  for  programming 
purposes.  In  the  context  of  this  Chapter,  they  will  by  used  to  provide  the  result 
of  bit-by-bit  operations  along  the  lines  of  the  rules  provided  above.  In  the 
following  examples,  the  base  number  system  is  indicated  in  parentheses: 


AND  (BIN) 


:  #  1100b 

# 

1100b 

:  #  1010b 

# 

1010b 

:RHS(2)  RHD 

RHS(l) 

# 

1000b 

OR  (BIN) 


:  #  1100b 

# 

1100b 

:  #  1010b 

# 

1010b 

:RHS(2)  OR 

RHS(15 

# 

1110b 
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XOR  (BIN) 

NOT  (HEX) 

:  #  1100b 

#  1100b 

:  #  1010b 

:  #  Ch 

#  1010b 

#  Ch 

:RHS(2)  XOR  RHS(l) 

:HOT  RHS(l) 

#  110b 

#  FFFFFFFFFFFFFFF3h 

The  BIT  menu 

The  BIT  menu,  available  through  the  BASE  ((.  J  sAse )  provides  the  following 
functions: 


SflSE  HEnu 

S.E-tfi  1 
?. LOGIC. . 

3.EIT..  V 

S.EYTE.. 

10.  £TH£ 

11.  RCHf  1 

1       1       1  IcflncL 

OK 

eiT  HEnu 

l.RL 

a.sL 

3.flSR 

H.SR 

5.RR 

e.EAfE.. 

1       1       1  IcHncUr 

OK 

Functions  RL,  SL,  ASR,  SR,  RR,  contained  in  the  BIT  menu,  are  used  to 
manipulate  bits  in  a  binary  integer.  The  definition  of  these  functions  are 
shov/n  belov^: 

RL:  Rotate  Left  one  bit,  e.g.,  #1 1 00b  ^  #1 001  b 

SL:    Shift  Left  one  bit,  e.g.,  #1 1 01  b  ^  #1 1 01  Ob 

ASR:  Arithmetic  Shift  Right  one  bit,  e.g.,  #1 1 0001  Ob  ^  #1  1 0001  b 

SR:    Shift  Right  one  bit,  e.g.,  #1 1  Oil  b  ^#1 1 01  b 

RR:    Rotate  Right  one  bit,  e.g.,  #1 1 01  b  ^  #11 1  Ob 

The  BYTE  menu 

The  BYTE  menu,  available  through  the  BASE  (I  r»  J  base  )  provides  the  following 
functions: 


EH^E  HEnu 

?. LOGIC. 

g.EIT..  

S.EYTE.. 

10.  £TH£ 

11.  RCH^ 

12.  HATH..  1 

1       1       1  IcflncL 

OK 

EYTE  HEnu 

l.RLE 

2.m 
3.SRE 
H.RRE 
E.EAfE.. 

1         1  1 

ICAnCLl 

OK 
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Functions  RLB,  SLB,  SRB,  RRB,  contained  in  the  BIT  menu,  are  used  to 
manipulate  bits  in  a  binary  integer.  The  definition  of  these  functions  are 
shown  below: 


RLB:  Rotate  Left  one  byte,  e.g.,  #11 00b  ^  #100 lb 
SLB:   Shift  Left  one  byte,  e.g.,  #1 1 01  b  ^  #1 1 01  Ob 
SRB:    Shift  Right  one  byte,  e.g.,  #1 1 01  1  b  ^#1 101  b 
RRB:    Rotate  Right  one  byte,  e.g.,  #1 1 01  b  ^  #1 1  1  Ob 


Hexadecimal  numbers  for  pixel  references 

Many  plot  option  specifications  use  pixel  references  as  input,  e.g.,  {  #332h 
#A23h  }  #Ah  0.  360.  ARC,  to  draw  an  arc  of  a  circle.   We  use  functions 
C^PX  and  PX^C  to  convert  quickly  between  user-unit  coordinates  and  pixel 
references.  These  functions  can  be  found  through  the  command  catalog 

Some  examples  are  shown  below: 


C+PX((2.  ,3.)) 

ttt  55hi#  £h3] 
PX-*Ca#  Rhi,#  102hiJ> 
(-5.5,-22.6) 


t^KIP  SKIP-H  H)EL   DEL-f  DEL  L  inS  i 
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Chapter  20 

Customizing  menus  and  keyboard 

Through  the  use  of  the  many  calculator  menus  you  have  become  familiar  with 
the  operation  of  menus  for  a  variety  of  applications.  Also,  you  are  familiar 
v/ith  the  many  functions  available  by  using  the  keys  in  the  keyboard,  v/hether 
through  their  main  function,  or  by  combining  them  v/ith  the  left-shift      J ), 
right-shift  ((.  r>  J)  or  ALPHA  [[alpha]  )  keys.  In  this  Chapter  v/e  provide  examples 
of  customized  menus  and  keyboard  keys  that  you  may  find  useful  in  your  own 
applications. 

Customizing  menus 

A  custom  menu  is  a  menu  created  by  the  user.  The  specifications  for  the  menu 
are  stored  into  the  reserved  variables  CST.  Thus,  to  create  a  menu  you  must 
put  together  this  variable  with  the  features  that  you  want  to  display  in  your 
menu  and  the  actions  required  by  the  soft  menu  keys.   To  show  examples  of 
customizing  menus  we  need  to  set  system  flag  1 1 7  to  SOFT  menu.  Make  sure 
you  do  this  before  continuing  (See  Chapter  2  for  instructions  on  setting  system 
flags). 

The  PRG/MODES/MENU  menu 

Commands  useful  in  customizing  menus  are  provided  by  the  MENU  menu, 
accessible  through  the  PRG  menu  (I  ^  Jfg    ).   Setting  system  flag  1  1 7  to 
SOFT  menu,  the  sequence  [  *i  Jfflg_  (W)  jUSllla  SDilill  produces  the  following 
MENU  soft  menu: 


The  functions  available  are: 

MENU:  Activates  a  menu  given  its  number 

CST:  Reference  to  the  CST  variable,  e.g.,  Li^lllliil  shows  CST  contents. 
TMENU:  Use  instead  of  MENU  to  create  a  temporary  menu  without 

overwriting  the  contents  of  CST 
RCLMENU:  Returns  menu  number  of  current  menu 
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Menu  numbers  (RCLMENU  and  MENU  functions) 

Each  pre-defined  menu  has  a  number  attached  to  it.  For  example,  suppose 
that  you  activate  the  MTH  menu  (I  <n  jf™  ).  Then,  using  the  function  catalog 
([  r>  J  CAT  )  find  function  RCLMENU  and  activate  it.  In  ALG  mode  simple  press 

after  RCLMENU  t  shows  up  in  the  screen.  The  result  is  the  number 
3.01 .  Thus,  you  can  activate  the  MTH  menu  by  using  MEINUG:!.  SI  !>,  in 
ALG,  or  3.  01  MENU,  in  RPN. 

Most  menus  can  be  activated  without  knowing  their  numbers  by  using  the 
keyboard.  There  are,  however,  some  menus  not  accessible  through  the 
keyboard.  For  example,  the  soft  menu  STATS  is  only  accessible  by  using 
function  MENU.  Its  number  is  96.01 .  Use  NENLif  96.  01  >  in  ALG  mode,  or 
96„  01  rIENU  in  RPN  mode  to  obtain  the  STAT  soft  menu. 


Note:  The  number  96.01  in  this  example  means  the  first  (01 )  sub-menu  of 
menu  96. 


Custom  menus  (MENU  and  TMENU  functions) 

Suppose  that  you  need  to  activate  four  functions  for  a  particular  application. 
Say,  that  you  need  to  be  able  to  quickly  access  the  functions  EXP,  LN, 
GAMMA  and  !  ([alpha] [    J [  2  J )  and  you  want  to  place  them  in  a  soft  menu  that 
you  will  keep  active  for  a  while.  You  could  do  this  by  creating  a  temporary 
menu  with  function  TMENU,  or  a  more  permanent  menu  with  function  MENU. 
The  main  difference  is  that  function  MENU  creates  variable  CST,  while 
TMENU  does  not.  With  variable  CST  created  permanently  in  your  sub- 
directory you  can  always  reactivate  the  menu  using  the  specifications  in  CST 
by  pressing  (^Jojstom  .  With  TMENU  the  menu  specifications  are  lost  after 
you  replace  the  temporary  menu  with  another  one. 

For  example,  in  RPN  mode,  a  menu  is  created  by  using: 
{EXP  LN  GAMMA  1}  TMENU 

or 

{EXP  LN  GAMMA  !}  (Mb}  MENU 
to  produce  the  following  menu: 
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To  activate  any  of  those  functions  you  simply  need  to  enter  the  function 
argument  (a  number),  and  then  press  the  corresponding  soft  menu  key. 


In  ALG  mode,  the  list  to  be  entered  as  argument  of  function  TMENU  or  MENU 
is  more  complicated: 

{{"exp","EXP("},{"ln","LN("},{"Gamma","GAMMA("},{"!","!{"}} 


The  reason  for  this  is  that,  in  RPN  mode,  the  command  names  are  both  soft 
menu  labels  and  commands.  In  ALG  mode,  the  command  names  will  produce 
no  action  since  ALG  functions  must  be  followed  by  parentheses  and 
arguments.  In  the  list  shown  above  (for  the  ALG  mode),  within  each  sub-list 
you  have  a  label  for  the  key,  e.g.,  "exp",  followed  by  the  way  that  the 
function  will  be  entered  in  the  stack  so  that  the  argument  to  the  function  can 
be  typed  at  the  prompt,  e.g.,  "EXP(".  We  need  not  worry  about  the  closing 
parenthesis,  because  the  calculator  will  complete  the  parentheses  before 
executing  the  function.    The  implementation  of  function  TMENU  in  ALG  mode 
with  the  argument  list  shown  above  is  as  follows.  First,  we  enter  the  list,  then 
we  produce  the  temporary  menu  (see  menu  key  labels)  by  using  function 
[  y  f .  We  also  show,  in  the  left-hand  side,  the  result  of 


pressing  the  1*11  soft  menu  key,  i.e.,  the  prompt 


After  typing 


gjlwra)  the  result  of  the  operation  is  shown  in  the  right-hand  side: 


«"exp"  "EXPt">  {"In" 
H"exp^  "EXPt"> {"In"  "L^ 
TMEHUtRHStD) 

HOVRLJ 

EXPt 


H"exp^"EXPt">  {"In"  "L^ 
TMEHUtRHStD) 

HOVRL 

S 

e 

S 


A  simpler  version  of  the  menu  can  be  defined  by  using 

MENU({{"EXP(","LN(","GAMMA(","!("}). 

Enhanced  RPN  menu 

The  list  presented  above  for  the  ALG  mode,  can  be  modified  slightly  to  use  in 
the  RPN  mode.  The  modified  list  will  look  like  this: 

{{"exp",EXP},{"ln",LN},{"Gamma",GAMMA},{"!",!}} 

You  can  try  using  this  list  with  TMENU  or  MENU  in  RPN  mode  to  verify  that 
you  get  the  same  menu  as  obtained  earlier  in  ALG  mode. 
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Menu  specification  and  CST  variable 

From  the  two  exercises  shown  above  we  notice  that  the  most  general  menu 
specification  list  include  a  number  of  sub-lists  equal  to  the  number  of  items  to 
be  displayed  in  your  custom  menu.  Each  sub-list  contains  a  label  for  the  menu 
key  followed  by  a  function,  expression,  label,  or  other  object  that  constitutes 
the  effect  of  the  menu  key  when  pressed.  Care  must  be  exercised  in 
specifying  the  menu  list  in  ALG  mode  versus  RPN  mode.  In  RPN  mode,  the 
menu  key  action  can  be  simply  a  calculator  command  (e.g.,  EXP,  LN,  etc.,  as 
shown  above),  while  in  ALG  mode  it  has  to  be  a  string  with  the  command 
prompt  whose  argument  needs  to  be  provided  by  the  user  before  pressing 
[ENTER}  and  completing  the  command.  The  examples  above  illustrate  the 
difference. 

The  general  form  of  the  argument  list  for  commands  TMENU  or  MENU  in  ALG 
mode  is 

{"labell  "/'functionl  (","lsl  (","rsl  ("},  {"Iabel2",  "function2(","ls2{","rs2{"},...} 

While,  in  RPN  mode,  the  argument  list  has  this  format 

{"labell",  functionl,  Isl,  rsl},  {"Iabel2",  function2,  Is2,  rs2},...} 

in  these  specifications,  functionl,  function  2,  etc.,  represent  the  main 
operation  of  the  key,  while  Isl,  Is2,      etc.,  represent  the  left-shift  operation 
of  the  key.  Similarly,  rsl,  rs2,       etc.,  represent  the  right-shift  operation  of 
the  key.  This  list  will  be  stored  in  variable  CST  if  command  MENU  is  used. 
You  can  have  a  different  CST  variable  in  each  sub-directory,  and  you  can 
always  replace  the  current  contents  of  CST  with  those  of  other  variables 
storing  the  properly  formatted  list  to  produce  another  custom  menu. 


Note:  You  can  use  a  21x8  GROB  (See  Chapter  22)  to  produce  an  icon  in 
the  soft  menu  keys.  As  an  example,  try,  in  RPN  mode: 

{{GROB  21  8  00000EF908FFF900FFF9B3FFF9A2FFF9A3FFF9A0FFF388FF  "hp"  }} 
(fMSl  MENU 

This  will  place  the  hp  logo  on  key  CZD  ■  Pressing  CZD  places  the  text  'hp'  in 
the  command  line. 
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Customizing  the  keyboard 

Each  key  in  the  keyboard  can  be  identified  by  two  numbers  representing  their 
row  and  column.    For  example,  the  VAR  key  ([  i»w  J )  is  located  in  row  3  of 
column  1,  and  will  be  referred  to  as  key  31 .  Now,  since  each  key  has  up  to 
ten  functions  associated  with  it,  each  function  is  specified  by  decimal  digits 
between  0  and  1,  according  to  the  following  specifications: 


.0  or  1,  unshifted  key 
.2,  key  combined  with  [Jnj 
.3,  key  combined  with  [  r»  J 
.4,  key  combined  with  [alpha] 
.5,  key  combined  with  Ialpha}1  <n  j 
.6,  key  combined  with  [alpha] [  r»  J 


0.01  or  0.11,  not  applicable 
.21,  key  simultaneous  with  (jTD 
.31,  key  simultaneous  with  [  r»  J 
.41,  key  combined  with  [alpha] 
.51 ,  [alpha]  key  simultaneous  with  [  <n  J 
.61,  [alpha]  key  simultaneous  with  [  J 


Thus,  the  VAR  function  will  be  referred  to  as  key  31 .0  or  31 .1,  while  the 
UPDIR  function  will  be  key  31 .2,  the  COPY  function  will  be  key  31 .3,  the 
upper-case  J  is  key  31 .4,  and  lower  case  j  is  key  31 .5.  (Key  31 .6  is  not 
defined).  In  general,  a  key  will  be  described  by  the  arrangement  XY.Z,  where 
X  =  row  number,  Y  =  column  number,  Z  =  shifting. 


We  can  combine  a  given  key  with  the  USER  key  (left-shift  associated  with  the 
[alpha]  key,  or  [  <n  ]liser   )  to  create  a  customized  key  action.  In  principle,  the 
entire  keyboard  can  be  re-defined  to  perform  a  number  of  customized 
operations. 


The  PRG/MODES/KEYS  sub-menu 

Commands  useful  in  customizing  the  keyboard  are  provided  by  the  KEYS 
menu  accessible  through  the  PRG  menu  (l^^lfflc   ).   Setting  system  flag  1 1 7 
to  SOFT  menu,  the  sequence  CfD  KSijla  ImiuEl 

produces  the  following  KEYS  soft  menu: 


The  functions  available  are: 
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ASN:  Assigns  an  object  to  a  key  specified  by  XY.Z 
STOKEYS:  Stores  user-defined  key  list 
RCLKEYS:  Returns  current  user-defined  key  list 

DELKEYS:  Un-assigns  one  or  more  keys  in  the  current  user-defined  key 
list,  tfie  arguments  are  eithier  0,  to  un-assign  all  user-defined 
keys,  or  XY.Z,  to  un-assign  key  XY.Z. 

Recall  current  user-defined  key  list 

Use  command  RCLKEYS  to  see  the  current  user-defined  key  list.  Before  any 
user-defined  key  assignments,  the  result  should  be  a  list  containing  the  letter  S, 
i.e.,  {S}. 

Assign  an  object  to  a  user-defined  key 

Suppose  that  you  want  to  have  access  to  the  old-fashioned  PLOT  command 
first  introduced  with  the  HP  48G  series  calculator,  but  currently  not  directly 
available  from  the  keyboard.  The  menu  number  for  this  menu  is  81 .01 .  You 
can  see  this  menu  active  by  using 

ALG  mode:   MENUO;:::!.  =  81  > 

RPN  mode:  81„81  (enM)  MENU  {mm} 

If  you  want  to  have  a  quick  way  to  activate  this  menu  from  the  keyboard,  you 

could  assign  this  menu  to  the  GRAPH  key  (CjT] )  v/hose  reference  number  is 
1  3.0,  i.e.,  first  row,  third  column,  main  function.  To  assign  an  object  to  a  key 
use  function  ASN,  as  follows: 

ALG  mode:   RSN  '■.  <  <  MENiJ  '■.  8 1  Q 1  '■'  >  ?  1 3 ,,  2- ') 

RPN  mode:  <<  18.01  MENU  >>  tjNfg)  13.8  [waj  FiSN 

Another  useful  menu  is  the  original  SOLVE  menu  (described  at  the  end  of 
Chapter  6  in  this  Guide),  which  can  be  activated  by  using  L  r»  J  (hold)  I  7  J . 

Operating  user-defined  keys 

To  operate  this  user-defined  key,  enter  [  *-\  )user  before  pressing  the  r«~l  key. 
Notice  that  after  pressing  I  *i  }usek    the  screen  shows  the  specification  lUSR 
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in  the  second  display  line.  Pressing  for  [  <n  )user  flP|  for  tfiis  example,  you 
sfiould  recover  tfie  PLOT  menu  as  follows: 


PTVFeTpPHRI    Et    lERHSEl  DRHK  I  DRHH 


If  you  fiave  more  tfian  one  user-defined  key  and  want  to  operate  more  tfian 
one  of  them  at  a  time,  you  can  lock  the  keyboard  in  USER  mode  by  entering 
(jn_loff«  [j^]usER    before  pressing  the  user-defined  keys.  With  the  keyboard 
locked  in  USER  mode,  the  specification  USR  will  be  shown  in  the  second 
display  line.   To  unlock  the  keyboard  press  [  *i  J"^^    once  more. 

Un-assigning  a  user-defined  key 

To  remove  the  assignment  performed  above,  use  function  DELKEYS,  as  follows: 
ALG  mode:  SELKEIVS 1 1 3 .  8  > 

RPN  mode:  1 3 ,,  8  DELKEVS 

Assigning  multiple  user-defined  keys 

The  simplest  way  to  assign  several  user-defined  is  to  provide  a  list  of 
commands  and  key  specifications.    For  example,  suppose  that  we  assign  the 
three  trigonometric  functions  (SIN,  COS,  TAN)  and  the  three  hyperbolic 
functions  (SINH,  COSH,  TANH)  to  keys  (jiJ  through  C2D  /  respectively,  as 
user-defined  keys.  In  RPN  mode  use: 

■i.  o  i  N  J  1  1 »  K.'  J         >  i^.vn  \  rii  -i  j  .i    .  t.i ,  o i  iin  n  i 't .    j  i_-L.ion ,  j.  ._i »  b  q  i 

f^nHji6.0>  [fNTH)  STOKE VS  [fNfa) 
In  ALG  mode  use: 

s I HH t:     1 4 .'■8 " coin ,  BTs ,    TRNH <  " ,  ' ^G^'£^ > >  '(Ji)"" ' 

Operate  these  keys  by  using,  for  example,  in  RPN  mode: 

[jj[^Lm_(jr)   [jj[;^ujER_(jr}  celC^ujE-C^ 

To  un-assign  all  user-defined  keys  use: 

ALG  mode:  DELKEVS  >:  8  >  RPN  mode:  8  DELKEVS 

Check  that  the  user-key  definitions  were  removed  by  using  function  RCLKEYS. 
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Chapter  21 

Programming  in  User  RPL  language 

User  RPL  language  is  the  programming  language  most  commonly  used  to 
program  the  calculator.  The  program  components  can  be  put  together  in  the 
line  editor  by  including  them  between  program  containers  ■<  s-  in  the 
appropriate  order.  Because  there  is  more  experience  among  calculator  users 
in  programming  in  the  RPN  mode,  most  of  the  examples  in  this  Chapter  will 
be  presented  in  the  RPN  mode.  Also,  to  facilitate  entering  programming 
commands,  we  suggest  you  set  system  flag  1 1  7  to  SOFT  menus.  The 
programs  work  equally  well  in  ALG  mode  once  they  have  been  debugged 
and  tested  in  RPN  mode.  If  you  prefer  to  work  in  the  ALG  mode,  simply  learn 
how  to  do  the  programming  in  RPN  and  then  reset  the  operating  mode  to 
ALG  to  run  the  programs.    For  a  simple  example  of  User  RPL  programming  in 
ALG  mode,  refer  to  the  last  page  in  this  chapter. 

An  example  of  programming 

Throughout  the  previous  Chapters  in  this  guide  we  have  presented  a  number 
of  programs  that  can  be  used  for  a  variety  of  applications  (e.g.,  programs 
CRMC  and  CRMT,  used  to  create  a  matrix  out  of  a  number  of  lists,  were 
presented  in  Chapter  10).  In  this  section  we  present  a  simple  program  to 
introduce  concepts  related  to  programming  the  calculator.  The  program  we 
will  write  will  be  used  to  define  the  function  f(x)  =  sinh(x)/(l  +x^),  which 
accepts  lists  as  argument  (i.e.,  x  can  be  a  list  of  numbers,  as  described  in 
Chapter  8).  in  Chapter  8  we  indicated  that  the  plus  sign,  ,  acts  as  a 
concatenation  operator  for  lists  and  not  to  produce  a  term-by-term  sum. 
Instead,  you  need  to  use  the  ADD  operator  to  achieve  a  term-by-term 
summation  of  lists.  Thus,  to  define  the  function  shown  above  we  will  use  the 
following  program: 

■''■•x'    STO  X  SINK  1  X  SQ  ADD  /    'x'    PURGE  S- 

To  key  in  the  program  follow  these  instructions: 


Keystroke  sequence: 

[  '  ]{AIMA}(P^(x}(y:)[STO>) 


Produces: 

'x'  STO 

X 


interpreted  as: 
Start  an  RPL  program 
Store  level  1  into  variable  x 
Place  X  in  level  1 
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SINK 

Calculate  sinh  of  level  1 

1  X  SQ 

Enter  1  and  calculate 

(33  Mzw_  BCEEa  BHiil  ITililiS 

ADD 

Calculate  (1+x^), 

/ 

then  divide 

'x' 

CID^«^  Swilll  iliSai  EEHHl 

PURGE 

Purge  variable  x 

Program  in  level  1 

To  save  the  program  use:  [  ' 

](4i™j(jnJ(g] 

Press  LhJ  to  recover  your  variable  menu,  and  evaluate  g(3.5)  by  entering  the 
value  of  the  argument  in  level  1  (I  3  Jl  •  Jt  5  }Ib^ter])  and  then  pressing  Sill. 
The  result  is  1 .2485...,  i.e.,  g(3.5)  =  1 .2485.  Try  also  obtaining  g({l  2  3}), 
by      entering      the       list      in       level       1       of      the  display: 

(Jx][i  (nDiF£JC2DiF£JCIDiSfS}    and  pressing  iiilll.    The  result  now  is 

{SINH(l)/2  SINH(2)/5  SINH(3)/1 0},  if  your  CAS  is  set  to  exact  mode.  If 
your  CAS  is  set  to  APPROXIMATE  mode,  the  result  will  be  {0.5876.. 
0.7253...  1.0017...}. 

Global  and  local  variables  and  subprograms 

The  program  ISSTSB,  defined  above,  can  be  displayed  as 

'x'    STO  X  SINH  1  X  SQ  ADD  /    'x'    PURGE  S- 

by  using  LitJ  WM. 

Notice  that  the  program  uses  the  variable  name  x  to  store  the  value  placed  in 
level  1  of  stack  through  the  programming  steps  'x'  sto.  The  variable  x, 
while  the  program  is  executing,  is  stored  in  your  variable  menu  as  any  other 
variable  you  had  previously  stored.  After  calculating  the  function,  the 
program  purges  (erases)  the  variable  x  so  it  will  not  show  in  your  variable 
menu  after  finishing  evaluating  the  program.  If  we  were  not  to  purge  the 
variable  x  within  the  program  its  value  would  be  available  to  us  after  program 
execution.  For  that  reason,  the  variable  x,  as  used  in  this  program,  is  referred 
to  as  a  global  variable.  One  implication  of  the  use  of  x  as  a  global  variable 
is  that,  if  we  had  a  previously  defined  a  variable  with  the  name  x,  its  value 
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would  be  replaced  by  the  value  that  the  program  uses  and  then  completely 
removed  from  your  variable  menu  after  program  execution. 
From  the  point  of  viev/  of  programming,  therefore,  a  global  variable  is  a 
variable  that  is  accessible  to  the  user  after  program  execution.  It  is  possible  to 
use  a  local  variable  within  the  program  that  is  only  defined  for  that  program 
and  will  not  be  available  for  use  after  program  execution.  The  previous 
program  could  be  modified  to  read: 

X       X  SINK  1  X  SQ  ADD  /  S-  S" 

The  arrow  symbol  (^)  is  obtained  by  combining  the  right-shift  key  CifD  v/ith 
the  i_0_J  key,  i.e.,  (j^l  — »;  .  Also,  notice  that  there  is  an  additional  set  of 
programming  symbols  (-K  s)  indicating  the  existence  of  a  sub-program, 
namely  -^K  x  sink  i  x  sq  add  /  within  the  main  program.  The  main 
program  starts  with  the  combination  ->  x,  which  represents  assigning  the 
value  in  level  1  of  stack  to  a  local  variable  x.  Then,  programming  flow 
continues  within  the  sub-program  by  placing  x  in  the  stack,  evaluating  SINH(x), 
placing  7  in  the  stack,  placing  x  in  the  stack,  squaring  x,  adding  7  to  x,  and 
dividing  stack  level  2  (SINH(x))  by  stack  level  1  (l+x^).  The  program  control 
is  then  passed  back  to  the  main  program,  but  there  are  no  more  commands 
between  the  first  set  of  closing  programming  symbols  f^^)  and  the  second  one, 
therefore,  the  program  terminates.  The  last  value  in  the  stack,  i.e.,  SINH(x)/ 
(1+x^),  is  returned  as  the  program  output. 

The  variable  x  in  the  last  version  of  the  program  never  occupies  a  place 
among  the  variables  in  your  variable  menu.  It  is  operated  upon  within  the 
calculator  memory  without  affecting  any  similarly  named  variable  in  your 
variable  menu.  For  that  reason,  the  variable  x  in  this  case  is  referred  to  as  a 
variable  local  to  the  program,  i.e.,  a  local  variable. 


Note:  To  modify  program  mm,  place  the  program  name  in  the  stack 
(CDSHK^),  then  use  ED^.  Use  the  arrow  keys  (c3DCDi^^)  to 
move  about  the  program.  Use  the  backspace/delete  key,  l_*J,  to  delete  any 
unwanted  characters.  To  add  program  containers  (i.e.,  s  s-),  use  l^r^l  « » , 
since  these  symbols  come  in  pairs  you  will  have  to  enter  them  at  the  start  and 
end  of  the  sub-program  and  delete  one  of  its  components  with  the  delete  key 
(3D  to  produce  the  required  program,  namely: 
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X        X  SINK   1   X  SQ  ADD 

When  done  editing  the  program  press  [waj  .  The 

modified  program  is  stored 

back  into  variable  SE3. 

Global  Variable  Scope 

Any  variable  that  you  define  in  the  HOME  directory  or  any  other  directory  or 
sub-directory  will  be  considered  a  global  variable  from  the  point  of  viev/  of 
program  development.  Hov/ever,  the  scope  of  such  variable,  i.e.,  the  location 
in  the  directory  tree  where  the  variable  is  accessible,  will  depend  on  the 
location  of  the  variable  within  the  tree  (see  Chapter  2). 

The  rule  to  determine  a  variable's  scope  is  the  following:  a  global  variable  is 
accessible  to  the  directory  v/here  it  is  defined  and  to  any  sub-directory 
attached  to  that  directory,  unless  a  variable  v/ith  the  same  name  exists  in  the 
sub-directory  under  consideration.  Consequences  of  this  rule  are  the  following: 

•  A  global  variable  defined  in  the  HOME  directory  will  be  accessible  from 
any  directory  within  HOME,  unless  redefined  within  a  directory  or  sub- 
directory. 

•  if  you  re-define  the  variable  within  a  directory  or  sub-directory  this 
definition  takes  precedence  over  any  other  definition  in  directories  above 
the  current  one. 

•  When  running  a  program  that  references  a  given  global  variable,  the 
program  will  use  the  value  of  the  global  variable  in  the  directory  from 
which  the  program  is  invoked.  If  no  variable  with  that  name  exist  in  the 
invoking  directory,  the  program  will  search  the  directories  above  the 
current  one,  up  to  the  HOME  directory,  and  use  the  value  corresponding 
to  the  variable  name  under  consideration  in  the  closest  directory  above 
the  current  one. 

A  program  defined  in  a  given  directory  can  be  accessed  from  that  directory 
or  any  of  its  sub-directories. 
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All  these  rule  may  sound  confusing  for  a  new  calculator  user.  They  all  can  be 
simplified  to  the  following  suggestion:  Create  directories  and  sub-directories 
with  meaningful  names  to  organize  your  data,  and  make  sure  you  have  all  the 
global  variables  you  need  within  the  proper  sub-directory. 


Local  Variable  Scope 

Local  variables  are  active  only  within  a  program  or  sub-program.  Therefore, 
their  scope  is  limited  to  the  program  or  sub-program  where  they're  defined. 
An  example  of  a  local  variable  is  the  index  in  a  FOR  loop  (described  later  in 
this  chapter),  for  example -^K  ->  n  x      in  for  j  x  next  n  ->list  s-  s- 

The  PRG  menu 

In  this  section  we  present  the  contents  of  the  PRG  (programming)  menu  with 
the  calculator's  system  flag  1 1 7  set  to  SOFT  menus.  With  this  flag  setting  sub- 
menus and  commands  in  the  PRG  menu  will  be  shown  as  soft  menu  labels. 
This  facilitates  entering  the  programming  commands  in  the  line  editor  when 
you  are  putting  together  a  program. 

To  access  the  PRG  menu  use  the  keystroke  combination  CjT]™g_  .  Within  the 
PRG  menu  we  identify  the  following  sub-menus  (press        to  move  to  the  next 
collection  of  sub-menus  in  the  PRG  menu): 


£THCK|  HEH  1  ERCH  |  TE^T  |  TYPE  |  LI^T 

GROe  1  PICT  |CHHR£|HODE£|  IR 

nil! 

timeTerrorT  Run 


Here  is  a  brief  description  of  the  contents  of  these  sub-menus,  and  their  sub- 
menus: 

STACK:  Functions  for  manipulating  elements  of  the  RPN  stack 

MEM:    Functions  related  to  memory  manipulation 

DIR:      Functions  related  to  manipulating  directories 
ARITH:  Functions  to  manipulate  indices  stored  in  variables 

BRCH:  Collection  of  sub-menus  with  program  branching  and  loop  functions 
IF:        IF-THEN-ELSE-END  construct  for  branching 
CASE:  CASE-THEN-END  construct  for  branching 
START:  START-NEXT-STEP  construct  for  branching 
FOR:     FOR-NEXT-STEP  construct  for  loops 


Page  21-5 


DO :      DO-U  NTI L-E  N  D  construct  for  loops 
WHILE:  WHILE-REPEAT-END  construct  for  loops 

TEST:    Comparison  operators,  logical  operators,  flag  testing  functions 

TYPE:     Functions  for  converting  object  types,  splitting  objects,  etc. 

LIST:      Functions  related  to  list  manipulation 

ELEM:    Functions  for  manipulating  elements  of  a  list 
PROC:  Functions  for  applying  procedures  to  lists 

GROB:  Functions  for  the  manipulation  of  grapfiic  objects 

PICT:     Functions  for  drawing  pictures  in  the  graphics  screen 

CHARS:  Functions  for  character  string  manipulation 

MODES:  Functions  for  modifying  calculator  modes 

FMT:     To  change  number  formats,  comma  format 
ANGLE:To  change  angle  measure  and  coordinate  systems 
FLAG:   To  set  and  un-set  flags  and  check  their  status 
KEYS:    To  define  and  activate  user-defined  keys  (Chapter  20) 
MENU:  To  define  and  activate  custom  menus  (Chapter  20) 
MISC:   Miscellaneous  mode  changes  (beep,  clock,  etc.) 

IN:       Functions  for  program  input 

OUT:     Functions  for  program  output 

TIME:    Time-related  functions 

ALRM:  Alarm  manipulation 

ERROR:  Functions  for  error  handling 

IFERR:    IFERR-THEN-ELSE-END  construct  for  error  handling 

RUN:    Functions  for  running  and  debugging  programs 

Navigating  through  RPN  sub-menus 

Start  with  the  keystroke  combination  (.  *i  J^c   ,  then  press  the  appropriate  soft- 
menu  key  (e.g.,  ilHili ).  If  you  want  to  access  a  sub-menu  within  this  sub- 
menu (e.g.,  liiiiCIHII  within  the  lllLlIijIlf  sub-menu),  press  the  corresponding  key. 
To  move  up  in  a  sub-menu,  press  the  [nxt)  key  until  you  find  either  the 
reference  to  the  upper  sub-menu  (e.g.,  iCHiiSS  within  the  S^SEt  sub-menu)  or 
to  the  PRG  menu  (i.e.,  IQl^EII ). 

Functions  listed  by  sub-menu 

The  following  is  a  listing  of  the  functions  within  the  PRG  sub-menus  listed  by 
sub-menu. 
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STACK 

MEM/DIR 

BRCH/IF 

BRCH/WHILE  TYPE 

DUP 

PURGE 

IF 

WHILE 

OBJ^ 

SWAP 

RCL 

THEN 

REPEAT 

^ARRY 

DROP 

STO 

ELSE 

END 

^LIST 

OVER 

PATH 

END 

^STR 

ROT 

CRDIR 

TEST 

^TAG 

UN  ROT 

PGDIR 

BRCH/CASE 

== 

^UNIT 

ROLL 

VARS 

CASE 

C^R 

ROLLD 

TVARS 

THEN 

< 

R^C 

PICK 

ORDER 

END 

> 

NUM 

UNPICK 

< 

CHR 

PICKS 

MEM/ARITH 

BRCH/START 

> 

DTAG 

DEPTH 

STO+ 

START 

AND 

EQ^ 

DUP2 

STO- 

NEXT 

OR 

TYPE 

DUPN 

STOx 

STEP 

XOR 

VTYPE 

DROP2 

STO/ 

NOT 

DROPN 

INCR 

BRCH/FOR 

SAME 

LIST 

DUPDU 

DECR 

FOR 

TYPE 

OBJ^ 

NIP 

SINV 

NEXT 

SF 

^LIST 

NDUPN 

SNEG 

STEP 

CF 

SUB 

SCONJ 

FS? 

REPL 

MEM 

BRCH/DO 

FC? 

PURGE 

BRCH 

DO 

FS?C 

MEM 

IFT 

UNTIL 

FC?C 

BYTES 

IFTE 

END 

LININ 

NEWOB 

ARCHI 

RESTO 
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LIST/ELEM 

GROB 

CHARS 

MODES/FLAG 

MODES/MISC 

GET 

^GROB 

SUB 

SF 

BEEP 

GETI 

BLANK 

REPL 

CF 

CLK 

PUT 

GOR 

POS 

FS? 

SYM 

PUTI 

GXOR 

SIZE 

FC? 

STK 

SIZE 

SUB 

NUM 

FS?C 

ARG 

POS 

REPL 

CHR 

FS?C 

CMD 

HEAD 

^LCD 

OBJ^ 

FC?C 

INFO 

TAIL 

LCD^ 

^STR 

STOP 

SIZE 

HEAD 

RCLF 

IN 

LIST/PROC 

ANIMATE 

TAIL 

RESET 

INFORM 

DOLIST 

SREPL 

NOVAL 

DOSUB 

PICT 

MODES/KEYS 

CHOOSE 

NSUB 

PICT 

MODES/FMT 

ASN 

INPUT 

ENDSUB 

PDIM 

STD 

STOKEYS 

KEY 

STREAM 

LINE 

FIX 

RECLKEYS 

WAIT 

REVLIST 

TUNE 

SCI 

DELKEYS 

PROMPT 

SORT 

BOX 

ENG 

SEQ 

ARC 

FM, 

MODES/MENU 

OUT 

PIXON 

ML 

MENU 

PVIEW 

PIXOF 

CST 

TEXT 

PIX? 

MODES/ANGLE 

TMENU 

CLLCD 

PVIEW 

DEG 

RCLMENU 

DISP 

PX^C 

RAD 

FREEZE 

C^PX 

GRAD 

MSGBOX 

RECT 

BEEP 

CYLIN 

SPHERE 
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TIME 

ERROR 

RUN 

DATE 

DOERR 

DBUG 

^DATE 

ERRN 

SST 

TIME 

ERRM 

ssT^^ 

^TIME 

ERRO 

NEXT 

TICKS 

LASTARG 

HALT 

KILL 

TIME/ALRM 

ERROR/IFERR 

OFF 

ACK 

IFERR 

ACKALARM 

THEN 

STOALARM 

ELSE 

RCLALARM 

END 

DELALARM 

FINDALARM 

Shortcuts  in  the  PRG  menu 

Many  of  the  functions  listed  above  for  the  PRG  menu  are  readily  available 
through  other  means: 

•  Comparison  operators      <,  <,  >,  >)  are  available  in  the  keyboard. 

•  Many  functions  and  settings  in  the  MODES  sub-menu  can  be 
activated  by  using  the  input  functions  provided  by  the  Imot)  key. 

•  Functions  from  the  TIME  sub-menu  can  be  accessed  through  the 
keystroke  combination  (j:^)  time  . 

•  Functions  STO  and  RCL  (in  MEM/DIR  sub-menu)  are  available  in  the 
keyboard  through  the  keys  (sroT)  and  (.  <n  jy^  . 

•  Functions  RCL  and  PURGE  (in  MEM/DIR  sub-menu)  are  available 
through  the  TOOL  menu  ((roaD). 

•  Within  the  BRCH  sub-menu,  pressing  the  left-shift  key  (I  <n  J)  or  the 
right-shift  key  (L    J)  before  pressing  any  of  the  sub-menu  keys,  v/ill 
create  constructs  related  to  the  sub-menu  key  chosen.  This  only  works 
v/ith  the  calculator  in  RPN  mode.  Examples  are  shov/n  below: 
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CH^E  ^THRT   FOR      DO  HHILE 


CA^E  ^THRT   FOR      DO  HHILE 


CA^E  ^TART   FOR      DO  HHILE 


C3 


2: 
l: 

-OR  4 

5TEP 


CA^E  ^TART   FOR      DO  HHILE 


CA^E  ^TART   FOR      DO  HHILE 


EDI 


>0  4 

JHTIL 
END 


CA^E  ^TART   FOR      DO  HHILE 


CSli:] 


CA^E  ^TART   FOR      DO  HHILE 


Notice  that  the  insert  prompt  (^)  is  available  after  the  key  word  for  each 
construct  so  you  can  start  typing  at  the  right  location. 

Keystroke  sequence  for  commonly  used  commands 

The  following  are  keystroke  sequences  to  access  commonly  used  commands 
for  numerical  programming  within  the  PRG  menu.  The  commands  are  first 
listed  by  menu: 
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DUP 

SWAP 

DROP 


(335?G_silili] 


■LLlj 


PURGE 
ORDER 


[  *n  J  fTiG     BliLili^i  aaJJiiij;  l!!l:.!.!.k.!;:! 

f  ,    \  oD/-     ■Ph:n"iai  fflr-'L-i-niai  e«:T:T:Ta-:i 

1  *n  J       iiiLiiin  Bucjiin  uuuua 


IF 

THEN 

ELSE 

END 


CASE 
THEN 
END 


Brji^p-JITIfi  ikSkotm  KKKTZn 
M^UlOll  lOlESlS  laiJiUI 


(jT}ffiG_ 

CH3™^      issa  ssm 


START 

NEXT 

STEP 


C5:]fflG_  SHMS  I^ESa  ESSili 

f  .    \  DD/~     aBbrciTH  ip^Fmnir;!  ir:'r::ri-s:-:s 


FOR 

NEXT 

STEP 


r~zr~\  DDr     H!!-'!-'!'::!T!H  !!B-:3>:q-nii  nmiTi':^ 


DO 

UNTIL 

END 


C53ffiG_iEElilIi 
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WHILE 

REPEAT 

END 


r^fflG  if;-"-; 
(33fflG_i 

/  ,    \  r:v:v:a-i-iii  irmTTirm  


>jl:lJl:ljJ 


nji:£nJi 


AND 

OR 

XOR 

NOT 

SAME 

SF 

CF 

FS? 

FC? 

FS?C 

FC?C 


(33fflG_ 
(33fflG_ 


SI':'!!"!  fNxf] 


'ju.ai 


mm 


[_/W(tJ 


[nxtJ 
(W) 


assail 


OBJ^ 
^ARRY 

^LIST 

fij!.S.!E.:2i!  »  JlJIdU 

^STR 

^TAG 

(jT}ffiG_ 

NUM 

a~fh~a~ju  r           -)  a-JITr"-!!! 

CHR 

iAJ.ii.ai  Ijvxrj  i3iJi]i 

TYPE 

UUJi  [N)<T J  iklU 

GET 

GETI 

PUT 

PUTI 

SIZE 

HEAD 

TAIL 


a-iS;?r3:-3!!  !r!3-lfl-:T<-a  m:r3nn 


I  .    \  nor     a-!E'a«a:-aii  iria-iB-3-i-a  ii-=r:ir;ir:B 

LJnJ  ™G_  unii  ui^iu 

C5D     SiSa  SZllI 

(  X    \         rE'3i3:'3u  rVlra^v  irirrrc-Ji 

fH'S^lj!  !rT!S'T|'a  |!!=!n!=:n!B 

C53ffl^  li^S  EilO  (W]  iGiiSIil 
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REVLIST 

SORT 

SEQ 


(3T]«?G_;;i;T:;.];;;;;;;, 
(3T]«?G_  ;;!;:;■:;.];;;;;;;, 


[NXTj 
(  NXT  1 


DEC 
RAD 


CST 

MENU 

BEEP 


f  .    \  nor     I       \  rTlTTrnii  anrrniTB 

UnJ  f"G     [MXTJ [jjjui:£]  iiHii'B  ■li^Ui!! 

I       1         rrr^Tn  r<WT;T;ara  rfP^iSiai  anriririB 


^  IfflUTTIVy  IL~I?I~P7|-?IB 


INFORM  (^PRc_[Nxr)l 

INPUT  CfD5?5-(^S 

MSGBOX  (33^  cw)a3iias  !II§33;a 

PVIEW  (33^  (W)S3lia!  13331:11 


DBUG 

SST 

SSTi 

HALT 

KILL 


(2TjfflG_(w][w]  101111  ilia 

/ — :  >                 I-  1  /  >  nir^iri-i-iin  ■■□■■■■■■■■■■ni 

(_  <n  JfflG_  [7Af][_/vxrJ  lUiJjiB  iHilSijjl 

C53fflG_  SHIES  E-EBIJ 

/ — :  \      _        ,  \  /  \  niPiin-i-HD  ■■■■■■nini— in 

(jnj  PRC    (jvxrj (jwtJ  ||Lj:|j.|j.||  ilJ.iJ.|J!lLill 


Programs  for  generating  lists  of  numbers 

Please  notice  that  the  functions  in  the  PRG  menu  are  not  the  only  functions  that 
con  be  used  in  programming.  As  a  matter  of  fact,  almost  all  functions  in  the 
calculator  can  be  included  in  a  program.  Thus,  you  can  use,  for  example, 
functions  from  the  MTH  menu.  Specifically,  you  can  use  functions  for  list 
operations  such  as  SORT,  2LIST,  etc.,  available  through  the  MTH/LIST  menu. 
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As  additional  programming  exercises,  and  to  try  the  keystroke  sequences 
listed  above,  we  present  herein  three  programs  for  creating  or  manipulating 
lists.  The  program  names  and  listings  are  as  follows: 


■■K        St  en  df        St  en  FOR     j   j   df  STEP  en  st  -  df  /  FLOOR  1  + 


REVLIST  DUP  DUP  SIZE  'n'  STO  SLIST  SWAP  TAIL  DUP  SIZE  1-1 
SWAP  FOR  j  DUP  ZLIST  SWAP  TAIL  NEXT  1  GET  n  ^LIST  REVLIST  'n' 
PURGE  S- 

The  operation  of  these  programs  is  as  follows: 

(1 )  LISC:  creates  a  list  of  n  elements  all  equals  to  a  constant  c. 
Operation:  enter  n,  enter  c,  press  ESm 

Example:  5  Iemter)  6.5        tSSS  creates  the  list:  {6.5  6.5  6.5  6.5  6.5} 

(2)  CRLST:  creates  a  list  of  numbers  from  ni  to  r\2  with  increment  An,  i.e., 
{ni,  n,+An,  nl+2-An,  ...  Pi+N-An  },  where  N=floor((n2-nT)/An)+l . 

Operation:  enter  n„  enter  n^,  enter  An,  press  iiiilillj! 

Example:  .5  («™)3.5  [mh).5  [mh)  jyiiiilSiiiy  produces:  {0.5  1  1 .5  2  2.5  3  3.5} 

(3)  CLIST:  creates  a  list  with  cumulative  sums  of  the  elements,  i.e.,  if  the 
original  list  is  {xi  X2  X3  ...  x^},  then  CLIST  creates  the  list: 

N 


use 

■^K  ^  n  X        1  n  FOR  j   x  NEXT  n  ^LIST  '»  '''f 


CRLST: 


CLIST: 


i=\ 

Operation:  place  the  original  list  in  level  1,  press  ES™. 
Example:  {1  2  3  4  5}  (^ESSii  produces  {1  361015}. 
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Examples  of  sequential  programming 

In  general,  a  program  is  any  sequence  of  calculator  instructions  enclosed 
between  the  program  containers  s:  and  s-.  Subprograms  can  be  included  as 
part  of  a  program.  Tfie  examples  presented  previously  in  tfiis  guide  (e.g.,  in 
Cfiapters  3  and  8)  6  can  be  classified  basically  into  two  types:  (a)  programs 
generated  by  defining  a  function;  and,  (b)  programs  tfiat  simulate  a  sequence 
of  stack  operations.  These  two  types  of  programs  are  described  next.  The 
general  form  of  these  programs  is  input^process^output,  therefore,  we  refer 
to  them  as  sequential  programs. 

Programs  generated  by  defining  a  function 

These  are  programs  generated  by  using  function  DEFINE  ([.  <n  jpg    )  with  on 
argument  of  the  form: 

'function_name(xi,  X2,  ...)  =  expression  containing  variables  x,,  X2, 

The  program  is  stored  in  a  variable  called  f unction_name.  When  the 
program  is  recalled  to  the  stack,  by  using  [  JSS!ujE"Eu°B"™1  The  program 
shows  up  as  follows: 


To  evaluate  the  function  for  a  set  of  input  variables  x,,  Xj,  in  RPN  mode, 
enter  the  variables  into  the  stack  in  the  appropriate  order  (i.e.,  x,  first, 
followed  by  Xj,  then  X3,  etc.),  and  press  the  soft  menu  key  labeled 
jEHa*™™™™.  The  calculator  will  return  the  value  of  the  function 
functlon_name(x,,  X2,  ...). 

Example:  Manning's  equation  for  wide  reciangular  channel. 
As  an  example,  consider  the  following  equation  that  calculates  the  unit 
discharge  (discharge  per  unit  width),  q,  in  a  wide  rectangular  open  channel 
using  Manning's  equation: 


^;  ^  X,,  X2, 


I,  ...  'expression  containing  variables  x,,  X2, 
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where      is  a  constant  that  depends  on  the  system  of  units  used  [C„  =  1 .0  for 
units  of  the  International  System  (S.I.),  and  Q  =  1 .486  for  units  of  the  English 
System  (E.S.)],  n  is  the  Manning's  resistance  coefficient,  which  depends  on  the 
type  of  channel  lining  and  other  factors,  yo  is  the  flow  depth,  and  Sq  is  the 
channel  bed  slope  given  as  a  dimensionless  fraction. 


Note:  Values  of  the  Manning's  coefficient,  n,  are  available  in  tables  as 
dimensionless  numbers,  typically  between  0.001  to  0.5.  The  value  of  Cu  is 
also  used  without  dimensions.  However,  care  should  be  taken  to  ensure  that 
the  value  of  yO  has  the  proper  units,  i.e.,  m  in  S.I.  and  ft  in  E.S.  The  result  for 
q  is  returned  in  the  proper  units  of  the  corresponding  system  in  use,  i.e.,  mVs 
in  S.I.  and  ftVs  in  E.S.  Manning's  equation  is,  therefore,  not  dimensionally 
consistent 

Suppose  that  we  want  to  create  a  function  q(Cu,  n,  yO,  SO)  to  calculate  the 
unit  discharge  q  for  this  case.  Use  the  expression 

'q(Cu,n,yO,SO)=Cu/n*yO"(5./3.)*VSO', 

as  the  argument  of  function  DEFINE.  Notice  that  the  exponent  5./3.,  in  the 
equation,  represents  a  ratio  of  real  numbers  due  to  the  decimal  points.  Press 
[  J ,  if  needed,  to  recover  the  variable  list.  At  this  point  there  will  be  a 
variable  called  lEH  in  your  soft  menu  key  labels.  To  see  the  contents  of  q, 
use  C2Dil?lflll.  The  program  generated  by  defining  the  function 
q(Cu,n,yO,SO)is  shown  as: 

^  Cu  n  yO  SO  'Cu/n*yO'^(5./3.)*VSO' 

This  is  to  be  interpreted  as  "enter  Cu,  n,  yO,  SO,  in  that  order,  then  calculate 
the  expression  between  quotes."   For  example,  to  calculate  q  for  Cu  =  1 .0,  n 
=  0.012,  yO  =  2  m,  and  SO  =  0.0001,  use,  in  RPN  mode: 

1  f^TER}  0.01 2  QntM)  2  (wth)  0.0001  Qnter}  Mm 

The  result  is  2.6456684  (or,  q  =  2.6456684  mVs). 
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You  can  also  separate  the  input  data  with  spaces  in  a  single  stack  line  rather 
than  using  (mb)  . 

Programs  that  simulate  a  sequence  of  stack  operations 

In  this  case,  the  terms  to  be  involved  in  the  sequence  of  operations  are 
assumed  to  be  present  in  the  stack.  The  program  is  typed  in  by  first  opening 
the  program  containers  with  [j^l  «>> .  Next,  the  sequence  of  operations  to 
be  performed  is  entered.  When  all  the  operations  have  been  typed  in,  press 
IfwraJ  to  complete  the  program.  If  this  is  to  be  a  once-only  program,  you  can 
at  this  point,  press  d^T)  to  execute  the  program  using  the  input  data  available. 
If  it  is  to  be  a  permanent  program,  it  needs  to  be  stored  in  a  variable  name. 

The  best  way  to  describe  this  type  of  programs  is  with  an  example: 

Example:  Velocity  head  for  a  rectangular  channel. 

Suppose  that  we  wont  to  calculate  the  velocity  head,  h^,  in  a  rectangular 
channel  of  width  b,  with  a  flow  depth  y,  that  carries  a  discharge  Q.  The 
specific  energy  is  calculated  as  h^  =  QV(2g(by)^),  where  g  is  the  acceleration 
of  gravity  (g  =  9.806  m/s^  in  S.I.  units  or  g  =  32.2  ft/s^  in  E.S.  units).  If  we 
were  to  calculate  h^  for  Q  =  23  cfs  (cubic  feet  per  second  =  ftVs),  b  =  3  ft, 
and  y  =  2  ft,  we  would  use:  h,  =  23V(2-32.2-  (3-2)2).  ^J^■^^  j^e  RPN 
modethe  calculator,  interactively,  we  can  calculate  this  quantity  as: 

□D     CTD  CxD  CID  CID  CZD  CZD  Cxj 

(3D     OD     ED     CD  S 

Resulting  in  0.228 1 74,  or  h,  =  0.228 1 74. 

To  put  this  calculation  together  as  a  program  we  need  to  have  the  input  data 
(Q,  g,  b,  y)  in  the  stack  in  the  order  in  which  they  will  be  used  in  the 
calculation,  in  terms  of  the  variables  Q,  g,  b,  and  y,  the  calculation  just 
performed  is  written  as  (do  not  type  the  following): 

y(ENm}  bCxDSD?^  g  CxDQDCxD  QSDj^CDS 
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As  you  can  see,  y  is  used  first,  then  we  use  b,  g,  and  Q,  in  that  order. 
Therefore,  for  the  purpose  of  this  calculation  we  need  to  enter  the  variables  in 
the  inverse  order,  i.e.,  (do  not  type  the  following): 

Q  {mCRj  g  [INTEK]  b  (.gVTHiJ  y  lENTER) 

For  the  specific  values  under  consideration  we  use: 

23  (mra]  32.2  Iwra]  3  {eNTER}2  {cnter} 


The  program  itself  will  contain  only  those  keystrokes  (or  commands)  that  result 
from  removing  the  input  values  from  the  interactive  calculation  shown  earlier, 
i.e.,  removing  Q,  g,  b,  and  y  from  (do  not  type  the  following): 

y(^  bCxDI^^^  g  CEDODCxD  QED^^CDS 
and  keeping  only  the  operations  shown  below  (do  not  type  the  following): 


Note:  When  entering  the  program  do  not  use  the  keystroke  CB> ,  instead  use 
the  keystroke  sequence:  I3D™g_ 


Unlike  the  interactive  use  of  the  calculator  performed  earlier,  we  need  to  do 
some  swapping  of  stack  levels  1  and  2  within  the  program.  To  write  the 
program,  we  use,  therefore: 


/   .     'I  nor-  »S'»»3"n 


Opens  program  symbols 

Multiply  y  with  b 

Square  (b  y) 

Multiply  (b-y)^  times  g 

Enter  a  2  and  multiply  it  with  g-  (b-y)^ 

Swap  Q  with  2-g-  (b-y)'^ 

Square  Q 

Swap  2-g-  (b-y)^  with 
Divide      by  2-g-  (b-y)^ 
Enter  the  program 


The  resulting  program  looks  like  this: 


SQ 


SWAP  SQ  SWAP  / 
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Note:  SQ  is  the  function  that  results  from  the  keystroke  sequence  I  *n   . 


Save  the  program  into  a  variable  called  hv: 

A  new  variable  SGCB  should  be  available  in  your  soft  key  menu.  (Press  I  vm  j 
to  see  your  variable  list.)  The  program  left  in  the  stack  can  be  evaluated  by 
using  function  EVAL.  The  result  should  be  0.228174...,  as  before.  Also,  the 
program  is  available  for  future  use  in  variable  ilUBI.  For  example,  for  Q 
0.5  mVs,  g  =  9.806  m/s^  b  =  1 .5  m,  and  y  =  0.5  m,  use: 

0.5        9.806       1 .5  CE;]  0.5  ISIiSS! 


Note:  [sFc]  is  used  here  as  an  alternative  to  [fAmsj  for  input  data  entry. 

The  result  now  is  2.2661 862351 8E-2,  i.e.,  hv  =  2.2661 862351 8x10^  m. 


Note:  Since  the  equation  programmed  in  SiSIS  is  dimensionally  consistent, 
we  can  use  units  in  the  input. 


As  mentioned  earlier,  the  two  types  of  programs  presented  in  this  section  are 
sequential  programs,  in  the  sense  that  the  program  flow  follows  a  single  path, 
i.e.,  INPUTS  OPERATION  ^OUTPUT.  Branching  of  the  program  flow  is 
possible  by  using  the  commands  in  the  menu  1.  <~i  J^g  iii|f|jj|ili .  More  detail  on 
program  branching  is  presented  below. 

Interactive  input  in  programs 

In  the  sequential  program  examples  shown  in  the  previous  section  it  is  not 
always  clear  to  the  user  the  order  in  which  the  variables  must  be  placed  in  the 
stack  before  program  execution.  For  the  case  of  the  program  SHSi,  written  as 

^Cu  n  yO  SO  'Cu/n^yC^  (5/3)  *a/sO' 
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it  is  always  possible  to  recall  the  program  definition  into  the  stack  (UiJlllliilllill) 
to  see  the  order  in  which  the  variables  must  be  entered,  namely,  ^Cu  n  yO 
so.  However,  for  the  case  of  the  program  IRSS,  its  definition 


■s  *  SQ  *  2  *  SWAP  SQ  SWAP  /  :^> 


does  not  provide  a  clue  of  the  order  in  which  the  data  must  be  entered,  unless, 
of  course,  you  are  extremely  experienced  with  RPN  and  the  User  RPL 
language. 

One  way  to  check  the  result  of  the  program  as  a  formula  is  to  enter  symbolic 
variables,  instead  of  numeric  results,  in  the  stock,  and  let  the  program  operate 
on  those  variables.  For  this  approach  to  be  effective  the  calculator's  CAS 
(Calculator  Algebraic  System)  must  be  set  to  symbolic  and  exact  modes. 
This  is  accomplished  by  using  L/wopfjiaBai,  and  ensuring  that  the  check  marks  in 
the  options  Numeric  and  Approx  are  removed.  Press  iiiH  iill  to  return 
to  normal  calculator  display.     Press  [  ym  j  to  display  your  variables  menu. 

We  will  use  this  latter  approach  to  check  what  formula  results  from  using  the 
program  illlEias  follows:  We  know  that  there  are  four  inputs  to  the  program, 
thus,  we  use  the  symbolic  variables  S4,  S3,  S2,  and  SI  to  indicate  the  stack 
levels  at  input: 

Ialpha]  fs]  nj~l  [enter]   [alpha]  {s}  nn  [entek]      [alpha]  (s\  n2~l  [enter]      [alpha]  (s]  en  [enter] 
Next,  press  IES3S.  The  resulting  formula  may  look  like  this 


if  textbook  style  is  selected.  Since  we  know  that  the  function  SQ(  )  stands  for 
x^,  we  interpret  the  latter  result  as 


^SQ{S4) / (S3*SQ(S2*S1) *2) ', 


if  your  display  is  not  set  to  textbook  style,  or  like  this. 


SQiS4) 


S3-SQ(S2-Sl)-2 
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54' 

2 -53 -(52 -51)'  ' 

which  indicates  the  position  of  the  different  stack  input  levels  in  the  formula. 
By  comparing  this  result  with  the  original  formula  that  we  programmed,  i.e., 

we  find  that  we  must  enter  y  in  stack  level  1  (SI),  b  in  stack  level  2  (S2),  g  in 
stack  level  3  (S3),  and  Q  in  stack  level  4  (S4). 

Prompt  with  an  input  string 

These  two  approaches  for  identifying  the  order  of  the  input  data  are  not  very 
efficient.  You  can,  however,  help  the  user  identify  the  variables  to  be  used  by 
prompting  him  or  her  with  the  name  of  the  variables.  From  the  various 
methods  provided  by  the  User  RPL  language,  the  simplest  is  to  use  an  input 
string  and  the  function  INPUT  (C5D™^  (^SEEB  tSSMS)  to  load  your  input 
data. 

The  following  program  prompts  the  user  for  the  value  of  a  variable  a  and 
places  the  input  in  stack  level  1 : 

■S  "Enter  a:  "  {"Ha:  "  {2  0}  V  }   INPUT  OBJ^  S- 

This  program  includes  the  symbol  ::  (tag)  and  ^-'(return),  available  through  the 

keystroke  combinations  (jT]U       and  (.    J     ^ ,  both  associated  with  the  [  •  J 

key.  The  tag  symbol  (::)  is  used  to  label  strings  for  input  and  output.  The 
return  symbol  (*j  is  similar  to  a  carriage  return  in  a  computer.  The  strings 
between  quotes  ("  ")  are  typed  directly  from  the  alphanumeric  keyboard. 

Save  the  program  in  a  variable  called  INPTa  (for  INPuT  a). 

Try  running  the  program  by  pressing  the  soft  menu  key  labeled  SSSSE. 
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Enter  a: 


The  result  is  a  stack  prompting  the  user  for  the  value  of  a  and  placing  the 
cursor  right  in  front  of  the  prompt  :a:  Enter  a  value  for  a,  say  35,  then  press 
(mh).    The  result  Is  the  input  string  :a:35  in  stack  level  1 . 


A  function  with  an  input  string 

If  you  v/ere  to  use  this  piece  of  code  to  calculate  the  function,  f(a)  =  2*0^^2+3, 
you  could  modify  the  program  to  read  as  follov/s: 

"Enter  a:  "  {"Ha:  "  {2  0}  V  } 
INPUT  OBJ^        a        '2*a''2  +  3' S- 


Save  this  new  program  under  the  name  'FUNCa'  (FUNCtion  of  a): 


Run  the  program  by  pressing  SIESj.  When  prompted  to  enter  the  value  of  a 
enter,  for  example,  2,  and  press  {.inter}  .  The  result  is  simply  the  algebraic 
2a^+3,  which  is  an  incorrect  result.  The  calculator  provides  functions  for 
debugging  programs  to  identify  logical  errors  during  program  execution  as 
shown  below. 


Debugging  the  program 

To  figure  out  why  it  did  not  work  we  use  the  DBUG  function  in  the  calculator 
as  follows: 

L  ■  jiCilillflH  [ENTER)  Copies  program  name  to  stack  level  1 

(jT}fflG_  SSISS  a3M  Starts  debugger 

iBEijlJJ  Step-by-step  debugging,  result:  "Enter  a:" 

mm  Result:  {"     a:"  {2  0}  V} 

kSHJj  Result:  user  is  prompted  to  enter  value  of  a 

CX)(^  Enter  a  value  of  2  for  a.  Result:  "^0:2" 
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Wi  Result:  a:2 

!kkuI4J  Result:  empty  stack,  executing  ->a 

I^Jlil  Result:  empty  stack,  entering  subprogram  « 

ilEilJ  Result:  '2*a"2+3' 

Result:  '2*a'^2+3',  leaving  subprogram  s- 
ISIE]I4J  Result:  '2*0^^2+3',  leaving  main  programs- 

Further  pressing  the  lEB0ii  soft  menu  key  produces  no  more  output  since  we 
have  gone  through  the  entire  program,  step  by  step.  This  run  through  the 
debugger  did  not  provide  any  information  on  why  the  program  is  not 
calculating  the  value  of  2a^+3  for  a  =  2.  To  see  what  is  the  value  of  a  in  the 
sub-program,  we  need  to  run  the  debugger  again  and  evaluate  a  within  the 
sub-program.  Try  the  following: 

[  vAn  J  Recovers  variables  menu 

[  '  jimTlSFl  lENm)  Copies  program  name  to  stack  level  1 

C^fflG_  (W](W)  SSIB!  SEEul      Starts  debugger 

S§Sij>l'l  Step-by-step  debugging,  result:  "Enter  a:" 

Result:  {"  *-6:"  {2  0}  V} 
"j'j'j'J."  Result:  user  is  prompted  to  enter  value  of  a 

rj^[ENm}  Enter  a  value  of  2  for  a.  Result:  "^0:2" 

■  .-.-A-  Result:  a:2 

Si§ij>l'S  Result:  empty  stack,  executing  ->a 

'^iit  Result:  empty  stack,  entering  subprogram  S 

At  this  point  we  are  within  the  subprogram  «  '2*3^2+3' s-  v^hich  uses  the 
local  variable  a.  To  see  the  value  of  a  use: 

{awha}[  <-i  ](a}[p/al]  This  indeed  shows  that  the  local  variable  a  =  2 

Let's  kill  the  debugger  at  this  point  since  we  already  know  the  result  we  will 
get.  To  kill  the  debugger  press  iuijlli.  You  receive  an  <!>  interrupted 
message  acknowledging  killing  the  debugger.    Press  [  ow  J  to  recover  normal 

calculator  display.  

Note:  In  debugging  mode,  every  time  we  press  ISjl4-ll  the  top  left  corner  of  the 
display  shows  the  program  step  being  executed.  A  soft  key  function  called 
is  also  available  under  the  iuilE  sub-menu  within  the  PRG  menu. 
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This  can  be  used  to  execute  at  once  any  sub-program  called  from  within  a 
main  program.  Examples  of  the  application  of  iSSiiwill  be  shown  later. 


Fixing  the  program 

The  only  possible  explanation  for  the  failure  of  the  program  to  produce  a 
numerical  result  seems  to  be  the  lack  of  the  command  ^NUM  after  the 
algebraic  expression  '2*a'^2+3'.  Let's  edit  the  program  by  adding  the 
missing  EVAL  function.  The  program,  after  editing,  should  read  as  follows: 

■s  "Enter  a:  "  {"<4a:  "  {2  0}  V  }  INPUT 
OBJ->  ->  a   -s  '2*a''2+3'  ^NUMS-  ;s- 

Store  it  again  in  variable  FUNCa,  and  run  the  program  again  with  a  =  2. 
This  time,  the  result  is  1 1,  i.e.,  2*2^+3  =  11. 

Input  string  for  two  or  three  input  values 

In  this  section  we  will  create  a  sub-directory,  within  the  directory  HOME,  to 
hold  examples  of  input  strings  for  one,  two,  and  three  input  data  values. 
These  will  be  generic  input  strings  that  can  be  incorporated  in  any  future 
program,  taking  care  of  changing  the  variable  names  according  to  the  needs 
of  each  program. 

Let's  get  started  by  creating  a  sub-directory  called  PTRICKS  (Programming 
TRICKS)  to  hold  programming  tidbits  that  we  can  later  borrow  from  to  use  in 
more  complex  programming  exercises.  To  create  the  sub-directory,  first  make 
sure  that  you  move  to  the  HOME  directory.  Within  the  HOME  directory,  use 
the  following  keystrokes  to  create  the  sub-directory  PTRICKS: 

Cv;](^Z™](^(g(Tl(g(7]gi(g(?](w^  Enter  directory  name  'PTRICKS' 

[jT] iSiai  m!xSm  EEiSill  Create  directory 

[  VAR  J  Recover  variable  listing 

A  program  may  have  more  than  3  input  data  values.  When  using  input 
strings  we  want  to  limit  the  number  of  input  data  values  to  5  at  a  time  for  the 
simple  reason  that,  in  general,  we  have  visible  only  7  stack  levels.  If  we  use 
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stack  level  7  to  give  a  title  to  the  input  string,  and  leave  stack  level  6  empty  to 
facilitate  reading  the  display,  v^e  have  only  stack  levels  1  through  5  to  define 
input  variables. 

Input  string  program  for  two  input  values 

The  input  string  program  for  two  input  values,  say  a  and  b,  looks  as  follov^s: 

■s  "Enter  a  and  b:  "  {"<-ia:<-ib:  "  {2  0}  V  }   INPUT  OBJ^  55- 

This  program  can  be  easily  created  by  modifying  the  contents  of  INPTa.  Store 
this  program  into  variable  INPT2. 

Application:  evaluating  a  function  of  tv^o  variables 

Consider  the  ideal  gas  law,  pV  =  nRT,  where  p  =  gas  pressure  (Pa),  V  =  gas 
volumefm'^),  n  =  number  of  moles  (gmol),  R  =  universal  gas  constant  = 
8.31451_J/(gmol*K),  and  T  =  absolute  temperature  (K). 

We  can  define  the  pressure  p  as  a  function  of  two  variables,  V  and  T,  as 
p(V,T)  =  nRT/V  for  a  given  mass  of  gas  since  n  will  also  remain  constant. 
Assume  that  n  =  0.2  gmol,  then  the  function  to  program  is 

p(V,  r)  =  8.3 145 1  •  0.2  •  -  =  (1 .662902  — )  •  - 

V  -K  V 

We  can  define  the  function  by  typing  the  following  program 

■S  T  '  (1 .  562902_J/K)  *  (T/V)'  55- 

and  storing  it  into  variable  li'lli. 

The  next  step  is  to  add  the  input  string  that  will  prompt  the  user  for  the  values 
of  V  and  T.  To  create  this  input  stream,  modify  the  program  in  SSuSi  to  read: 

■s  "Enter  V  and  T:  "  {"<-'  :V:^  :T:  "  {2  0}  V  } 
INPUT  OBJ^  T  '(1.662902  J/K)*(T/V)'  S- 
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Store  the  new  program  back  into  variable  UlilliH.  Press  ililK  to  run  the  program. 
Enter  values  of  V  =  0.01_m'^3  and  T  =  300_K  in  the  input  string,  then  press 
IfA/THj .   The  result  is  49887.06_J/m'^3.  The  units  of  J/m'^S  are  equivalent  to 
Pascals  (Pa),  the  preferred  pressure  unit  in  the  S.I.  system. 


Note:  because  v/e  deliberately  included  units  in  the  function  definition,  the 
input  values  must  have  units  attach  to  them  in  input  to  produce  the  proper 
result. 


Input  string  program  for  three  input  values 

The  input  string  program  for  three  input  values,  say  a  ,b,  and  c,  looks  as 
follov/s: 

"Enter  a,   b  and  c:  "  {"•^    :a:^    :b:<-'    :c:  "  {2  0}  V  } 

INPUT  OBj^ 

This  program  can  be  easily  created  by  modifying  the  contents  of  INPT2  to 
make  it  look  like  shown  immediately  above.  The  resulting  program  can  then 
be  stored  in  a  variable  called  INPT3.  With  this  program  we  complete  the 
collection  of  input  string  programs  that  will  allow  us  to  enter  one,  two,  or  three 
data  values.  Keep  these  programs  as  a  reference  and  copy  and  modify  them 
to  fulfill  the  requirements  of  new  programs  you  write. 

Applicatioir.  evaluating  a  function  of  three  variables 

Suppose  that  we  want  to  program  the  ideal  gas  law  including  the  number  of 
moles,  n,  as  an  additional  variable,  i.e.,  we  want  to  define  the  function 

;.(F,r,«)  =  (8.31451_^)^, 

and  modify  it  to  include  the  three-variable  input  string.  The  procedure  to  put 
together  this  function  is  very  similar  to  that  used  earlier  in  defining  the  function 
p(V,T).  The  resulting  program  will  look  like  this: 

«  "Enter  V,  T,  and  n:"  {"  :¥:<-'  -.l:*-^  :n:"  {2  0}  V  } 
INPUT  OBJ^  T  n     '  (8  .  31451_J/ (K*mol)  )  *  (n*T/V)  ' 

Store  this  result  back  into  the  variable  11311. To  run  the  program,  press  wiiSS. 
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Enter  values  of  V  =  0.01_m'^3,  T  =  300_K,  and  n  =  0.8_mol.  Before  pressing 
[INTER] ,  tfie  stack  will  look  like  this: 

Enter  Vj        and  n: 


iV:0.01_m-^3 

iT:300_K 

:n:0.S_mol 


Press  to  get  the  result  1 99548.24_J/m''3,  or  1 99548. 24_Pa  =  199.55 
kPa. 


Input  through  input  forms 

Function  INFORM  (C5D5?c_  (W)ligili  lEIIIiEEI.)  can  be  used  to  create  detailed 
input  forms  for  a  program.  Function  INFORM  requires  five  arguments,  in  this 
order: 


1 .  A  title:  a  character  string  describing  the  input  form 

2.  Field  definitions:  a  list  v/ith  one  or  more  field  definitions  {si  S2  ...  s„}, 
where  each  field  definition,  s,,  can  have  one  of  two  formats: 

a.  A  simple  field  label:  a  character  string 

b.  A  list  of  specifications  of  the  form  {"label"  "helplnfo"  typeo 
type,  ...  type  J.  The  "label"  is  a  field  label.  The  "helplnfo" 
is  a  character  string  describing  the  field  label  in  detail,  and 
the  type  specifications  is  a  list  of  types  of  variables  allowed 
for  the  field  (see  Chapter  24  for  object  types). 

3.  Field  format  information:  a  single  number  col  or  a  list  {col  tabs}.  In 
this  specification,  col  is  the  number  of  columns  in  the  input  box,  and 
tabs  (optional)  specifies  the  number  of  tab  stops  between  the  labels 
and  the  fields  in  the  form.  The  list  could  be  an  empty  list.  Default 
values  are  col  =  1  and  tabs  =  3. 

4.  List  of  reset  values:  a  list  containing  the  values  to  reset  the  different 
fields  if  the  option  llj!l-S-ilLil  is  selected  while  using  the  input  form. 

5.  List  of  initial  values:  a  list  containing  the  initial  values  of  the  fields. 
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The  lists  in  items  4  and  5  can  be  empty  lists.  Also,  if  no  value  is  to  be 
selected   for   tfiese   options   you   can    use   the    NOVAL  command 

(c^ffiG_(W)iaEii  mns). 

After  function  INFORM  is  activated  you  will  get  as  a  result  either  a  zero,  in 
case  the  Hilil!s3JI  option  is  entered,  or  a  list  with  the  values  entered  in  the  fields 
in  the  order  specified  and  the  number  1,  i.e.,  in  the  RPN  stack: 


2:  {Vi    V2    ...  Vn) 

1:  1 


Thus,  if  the  value  in  stack  level  1  is  zero,  no  input  was  performed,  while  it  this 
value  is  1,  the  input  values  are  available  in  stack  level  2. 
Example  1  -  As  an  example,  consider  the  following  program,  INFPl  (INput 
Form  Program  1)  to  calculate  the  discharge  Q  in  an  open  channel  through 
Chezy's  formula:  Q  =  C-(R-S)'^^,  where  C  is  the  Chezy  coefficient,  a  function 
of  the  channel  surface's  roughness  (typical  values  80-150),  R  is  the  hydraulic 
radius  of  the  channel  (a  length),  and  S  is  the  channel  bed's  slope  (a 
dimensionless  numbers,  typically  0.01  to  0.000001).  The  following  program 
defines  an  input  form  through  function  INFORM: 

"  CHEZY'S  EQN"  {  {  "C:"  "Chezy's  coefficient"  0}  {  "R:" 
"Hydraulic  radius"  0  }  {  "S:"  "Channel  bed  slope"  0}  }  {  } 
{    120   1    .0001}    {   110  1.5    .00001    }      INFORM  S- 

In  the  program  we  can  identify  the  5  components  of  the  input  as  follows: 

1.  Title:  "  CHEZY'S  EQN" 

2.  Field  definitions:  there  are  three  of  them,  with  labels  "C:",  "R:",  "S:", 
info  strings  "Chezy  coefficient",  "Hydraulic  radius",  "Channel  bed 
slope",  and  accepting  only  data  type  0  (real  numbers)  for  all  of  the 
three  fields: 

{  {  "C:"  "Chezy's  coefficient"  0}  {  "R:"  "Hydraulic 
radius"  0   }    {   "S:"  "Channel  bed  slope"  0}  } 

3.  Field  format  information:  {   }  (an  empty  list,  thus,  default  values  used) 
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4.  List  of  reset  values:  {  120  1  .0001  } 

5.  List  of  initial  values:  {   110  1.5   .00001  } 


Save  tfie  program  into  variable  INFPl .  Press  ItSEEE!  to  run  tfie  program.  Tfie 
input  form,  v/itfi  initial  values  loaded,  is  as  follows: 


To  see  tfie  effect  of  resetting  these  values  use  [.nxt)  ISiEliCI  (select  Reset  all  to 
reset  field  values): 


CHEZV'S  E4n 


110  


.0001 


CHnCL    OK    HRE^ET KALC  TYPE£  CAnCL  OK 


Nov/,  enter  different  values  for  tfie  three  fields,  say,  C  =  95,  R  =  2.5,  and  S  = 
0.003,  pressing  after  entering  each  of  these  new  values.   After  these 

substitutions  the  input  form  will  look  like  this: 


Now,  to  enter  these  values  into  the  program  press  iiLlEilll  once  more.  This 
activates  the  function  INFORM  producing  the  following  results  in  the  stack: 


3: 

2: 

{95.  £.5  .003) 

l: 

 1. 

p  iFuncoiinpToi  1 
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Thus,  we  demonstrated  the  use  of  function  INFORM.  To  see  how  to  use  these 
input  values  in  a  calculation  modify  the  program  as  follows: 

"  CHEZY'S  EQN"  {  {  "C:"  "Chezy's  coefficient"  0}  {  "R:" 
"Hydraulic  radius"  0  }  {  "S:"  "Channel  bed  slope"  0}  }  {  } 
{  120  1  .0001}  {  110  1.5  .00001  }  INFORM  IF  THEN  OBJ->  DROP  ^ 
C  R  S  'C*(R*S)'  ^NUM  "Q"  ^TAG  ELSE  "Operation  cancelled" 
MSGBOX  END  3- 

The  program  steps  shown  above  after  the  INFORM  command  include  a 
decision  branching  using  the  IF-THEN-ELSE-END  construct  (described  in  detail 
elsewhere  in  this  Chapter).  The  program  control  can  be  sent  to  one  of  two 
possibilities  depending  on  the  value  in  stack  level  1 .  If  this  value  is  1  the 
control  is  passed  to  the  commands: 

OBJ^  DROP  ->  C  R  S    ''C*V(R*S)'    ^NUM  "Q"  ^TAG 

These  commands  will  calculate  the  value  of  Q  and  put  a  tag  (or  label)  to  it. 
On  the  other  hand,  if  the  value  in  stack  level  1  is  0  (which  happens  when  a 
HilIlfliLa  is  entered  while  using  the  input  box) ,  the  program  control  is  passed  to 
the  commands: 

"Operation  cancelled"  MSGBOX 

These  commands  will  produce  a  message  box  indicating  that  the  operation 
was  cancelled. 


Note:  Function  MSGBOX  belongs  to  the  collection  of  output  functions  under 
the  PRO/OUT  sub-menu.  Commands  IF,  THEN,  ELSE,  END  are  available 
under  the  PRG/BRCH/IF  sub-menu.  Functions  OBJ^,  ^TAG  are  available 
under  the  PRG/TYPE  sub-menu.  Function  DROP  is  available  under  the 
PRG/STACK  menu.  Functions  ->  and  ^NUM  are  available  in  the  keyboard. 


Example  2  -  To  illustrate  the  use  of  item  3  (Field  format  information)  in  the 
arguments  of  function  INFORM,  change  the  empty  list  used  in  program  INFPl 
to  {  2  1  },  meaning  2,  rather  than  the  default  3,  columns,  and  only  one  tab 
stop  between  labels  and  values.  Store  this  new  program  in  variable  INFP2: 
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■s  "  CHEZY'S  EQN"  {  {  "C : "  "Chezy' s  coefficient"  0} 
{  "R:"  "Hydraulic  radius"  0  }  {  "S:"  "Channel  bed  slope" 
0}  }  {  2  1  }  {  120  1  .0001  }  {  110  1.5  .00001  }  INFORM 
IF  THEN  OBJ^  DROP  ^  C  R  S  'C*  (R*S)  '  ^NUM  "Q"  ^TAG  ELSE 
"Operation  cancelled"  MSGBOX  END 

Running  program  UlUiti  produces  the  following  input  form: 


1.5 

S:  .00001 

EDITI         1         1         ICHnCLl  OK 

Example  3  -  Change  the  field  format  information  list  to  {  3  0  }  and  save  the 
modified  program  into  variable  INFP3.  Run  this  program  to  see  the  new  input 
form: 


m  CHEZVS 

E4n^^^ 

raii0 

f   R:  1.5 

S:  .0001 

EDITi         1         1         ICHnCLl  OK 

Creating  a  choose  box 

Function  CHOOSE  {[^i',^[NxPiMEm  m^m)  allov/s  the  user  to  create  a 
choose  box  in  a  program.  This  function  requires  three  arguments: 

1 .  A  prompt  (a  character  string  describing  the  choose  box) 

2.  A  list  of  choice  definitions  {ci  C2  ...  c^}.  A  choice  definition  C|  can 
have  any  of  two  formats: 

a.  An  object,  e.g.,  a  number,  algebraic,  etc.,  that  will  be 
displayed  in  the  choose  box  and  will  also  be  the  result  of  the 
choice. 

b.  A  list  {object_displayed  object_result}  so  that 
obiect_displayed  is  listed  in  the  choose  box,  and 
object_result  is  selected  as  the  result  if  this  choice  is  selected. 

3.  A  number  indicating  the  position  in  the  list  of  choice  definitions  of  the 
default  choice.  If  this  number  is  0,  no  default  choice  is  highlighted. 
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Activation  of  the  CHOOSE  function  will  return  eitfier  a  zero,  if  a  ll^l±lii^[i!y  action 
is  used,  or,  if  a  cfioice  is  made,  the  choice  selected  (e.g.,  v)  and  the  number  1, 
i.e.,  in  the  RPN  stack: 

[Y:  ^ 
1:  1 


Example  1  -  Manning's  equation  for  calculating  the  velocity  in  an  open 
channel  flov/  includes  a  coefficient,  Q,  v^hich  depends  on  the  system  of  units 
used.  If  using  the  S.I.  (Systeme  International),  =  1 .0,  while  if  using  the  E.S. 
(English  System),  C^,  =  1.486.  The  following  program  uses  a  choose  box  to 
let  the  user  select  the  value  of  by  selecting  the  system  of  units.  Save  it  into 
variable  CHPl  (CHoose  Program  1): 

«  "Units  coefficient"   {    {   "S.I.   units"  1} 
{   "E.S.   units"  1.486}      }    1  CHOOSE  S- 


Running  this  program  (press  lEilMII)  shows  the  following  choose  box: 


5: 

Unitf  '-.tiffi.'-.i.inX 

4: 

3: 

E.£.  unit; 

P: 

Depending  on  whether  you  select  s.i.  units  or  e.s.  units,  function 
CHOOSE  places  either  a  value  of  1  or  a  value  of  1 .486  in  stack  level  2  and 
a  1  in  level  1 .  If  you  cancel  the  choose  box,  CHOICE  returns  a  zero  (0). 

The  values  returned  by  function  CHOOSE  can  be  operated  upon  by  other 
program  commands  as  shown  in  the  modified  program  CHP2: 

«  "Units  coefficient"  {  {  "S.I.  units"  1}  {  "E.S.  units" 
1.486}  }  1  CHOOSE  IF  THEN  "Cu"  ^TAG  ELSE  "Operation 
cancelled"  MSGBOX  END  S- 


The  commands  after  the  CHOOSE  function  in  this  new  program  indicate  a 
decision  based  on  the  value  of  stack  level  1  through  the  IF-THEN-ELSE-END 
construct.  If  the  value  in  stack  level  1  is  1,  the  commands  "Cu"  ^TAG  will 
produced  a  tagged  result  in  the  screen.  If  the  value  in  stack  level  1  is  zero. 
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the  commands  "Operation  cancelled"  MSGBOX  will  show  a  message 
box  indicating  that  the  operation  was  cancelled. 

Identifying  output  in  programs 

The  simplest  way  to  identify  numerical  program  output  is  to  "tag"  the  program 
results.  A  tag  is  simply  a  string  attached  to  a  number,  or  to  any  object.  The 
string  will  be  the  name  associated  with  the  object.  For  example,  earlier  on, 
when  debugging  programs  INPTa  (or  INPTl)  and  INPT2,  we  obtained  as 
results  tagged  numerical  output  such  as  :  a :  35 . 

Tagging  a  numerical  result 

To  tag  a  numerical  result  you  need  to  place  the  number  in  stack  level  2  and 
the  tagging  string  in  stack  level  2,  then  use  the  — >TAG  function  (C5D  ^ 
Uliil  I  ^liiE)  For  example,  to  produce  the  tagged  result  B :  5  . ,  use: 

Decomposing  a  tagged  numerical  result  into  a  number  and  a  tag 

To  decompose  a  tagged  result  into  its  numerical  value  and  its  tag,  simply  use 
function  OBJ^  (CSD™^  SBEEIIEISI^I).  The  result  of  decomposing  a  tagged 
number  with  — >OBJ  is  to  place  the  numerical  value  in  stack  level  2  and  the  tag 
in  stack  level  1 .    If  you  are  interested  in  using  the  numerical  value  only,  then 
you  will  drop  the  tag  by  using  the  backspace  key  (.  4  J .  For  example, 
decomposing  the  tagged  quantity  B:  5  (see  above),  will  produce: 


4: 

3: 

2: 

5 

l: 

"B" 

OEJ-f|-tflRRV|-H.IST|  -tSTR 

-HflG  l-HiniT 

^'De-tagging"  a  tagged  quantity 

"De-tagging"  means  to  extract  the  object  out  of  a  tagged  quantity.  This 
function  is  accessed  through  the  keystroke  combination:  (3D  ^  SuSSjS 
iNXT]  1313113.    For  example,  given  the  tagged  quantity  a :  2,  DTAG  returns  the 
numerical  value  2. 
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Note:  For  mathematical  operations  with  tagged  quantities,  the  calculator  will 
"detag"  the  quantity  automatically  before  the  operation.  For  example,  the  left- 
hand  side  figure  below  shows  two  tagged  quantities  before  and  after  pressing 
the  I  X  J  key  in  RPN  mode: 


3: 
2: 

E:5 

l: 

fl:4 

OEJ-f|-tflRRV|-H.IST|  -tSTR 

-HflG  l-HiniT 

T  ■ 

3: 
2: 

l: 

20 

OEJ-f|-tflRRV|-H.IST|  -tSTR 

-HflG  l-HiniT 

Examples  of  tagged  output 

Example  1  -  tagging  output  from  function  FUNCa 

Let's  modify  the  function  FUNCa,  defined  earlier,  to  produce  a  tagged  output. 
Use  (.  J  liilililSllLl  to  recall  the  contents  of  FUNCa  to  the  stack.  The  original 
function  program  reads 

■s  "Enter  a:  "  {"•^a:  "   {2  0}  V  }   INPUT  OBJ-^  ^  a « 
'2*a''2  +  3'  ^NUM  S-  S- 

Modify  it  to  read: 

■s  "Enter  a:  "  {"<4a:  "  {2  0}  V  }   INPUT  OBJ^  ^  a « 
'2*a^2+3'  ^NUM  "F"  STAGS' 


Store  the  program  back  into  FUNCa  by  using  [  *i  J  mHHSS.  Next,  run  the 
program  by  pressing  lllll'aij.  Enter  a  value  of  2  when  prompted,  and  press 
[entik)  .  The  result  is  now  the  tagged  result  F :  11 . 

Example  2  -  tagging  input  and  output  from  function  FUNCa 
In  this  example  we  modify  the  program   FUNCa  so  that  the  output  includes 
not  only  the  evaluated  function,  but  also  a  copy  of  the  input  with  a  tag. 
Use  CED  ISmiflH  to  recall  the  contents  of  FUNCa  to  the  stack: 

■s  "Enter  a:  "  {"«4a:  "  {2  0}  V  }   INPUT  OBJ^  ^  a  -s 
'2*a^2  +  3'  ^NUM  "F"  STAGS'  S- 

Modify  it  to  read: 

•s  "Enter  a:  "  {"<4a:  "  {2  0}  V  }   INPUT  OBJ^  ^  a  « 
'2*a^2  +  3'  EVAL  "f"  -^TAG  a  SWAP:^=■  S- 
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(Recall  that  the  function  SWAP  is  available  by  using  C2D«5_  ^3313  laEEl). 
Store  the  program  back  into  FUNCa  by  using  (.  *i  J  UliSS.  Next,  run  the 
program  by  pressing  OQII^  .   Enter  a  value  of  2  when  prompted,  and  press 
[mm].  The  result  is  now  tv/o  tagged  numbers  a : 2  .  in  stack  level  2,  and  F:  11 . 
in  stack  level  1 . 


Note:  Because  we  use  an  input  string  to  get  the  input  data  value,  the  local 
variable  a  actually  stores  a  tagged  value  (  :a:2,  in  the  example  above). 
Therefore,  we  do  not  need  to  tag  it  in  the  output.  All  what  we  need  to  do  is 
place  an  a  before  the  SWAP  function  in  the  subprogram  above,  and  the 
tagged  input  is  placed  in  the  stack.  It  should  be  pointed  out  that,  in 
performing  the  calculation  of  the  function,  the  tag  of  the  tagged  input  a  is 
dropped  automatically,  and  only  its  numerical  value  is  used  in  the  calculation. 


To  see  the  operation  of  the  function  FUNCa,  step  by  step,  you  could  use  the 
DBUG  function  as  follows: 


Copies  program  name  to  stack  level  1 

Starts  debugger 

Step-by-step  debugging,  result:  "Enter  a:" 

Baara  i  b 

Result:  {"        {2  0}  V} 

KKXn  1  B 

Result 

user  is  prompted  to  enter  value  of  a 

Enter 

a  value  of  2  for  a.  Result:  "^0:2" 

Result 

a:2 

mm 

Result 

empty  stack,  executing  ^a 

KKXn  1  B 

Result 

empty  stack,  entering  subprogram  « 

Baara  i  b 

Result 

'2*a'^2-F3' 

Baara  i  b 

Result 

empty  stack,  calculating 

KKXn  1  B 

Result 

11., 

Result 

iiiifiUi 

Result 

F:  11. 

........4... 

Result 

a:2. 

KKXn  1  B 

Result 

swap  levels  1  and  2 

leaving  subprogram 

leaving  main  program 
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Example  3  -  tagging  input  and  output  from  function  p(V,T) 
In  this  example  we  modify  tfie  program  BI3BI  so  tfiat  tfie  output  tagged  input 
values  and  tagged  result.    Use  I  r>  jSrH  to  recall  tfie  contents  of  tfie  program 
to  the  stack: 

■s  "Enter  V,  T,  and  n:"  {"  ^  :V:^  iT:*-"  :n:"  {2  0}  V  } 
INPUT  OBJ-)'  ->V  T  n     '  (8  .  31451_J/ (K*mol)  )  *  (n*T/V) '  'i^ 

Modify  it  to  read: 

■s  "Enter  V,    T  and  n:"   {"<-'    :V:<-'    :  T : :n:"     {2  0}  V  } 
INPUT  OBJ^  ^  V  T  n  -s  V  T  n 
'(8.31451_J/ (K*mol)  )  *  (n*T/V)'  EVAL  "p"  ^TAG  S- 


Note:  Notice  that  we  have  placed  the  calculation  and  tagging  of  the  function 
p(V,T,n),  preceded  by  a  recall  of  the  input  variables  V  T  n,  into  a  sub-program 
[the  sequence  of  instructions  contained  within  the  inner  set  of  program 
symbols  s  s-  ].  This  is  necessary  because  without  the  program  symbol 
separating  the  two  listings  of  input  variables  (v  T  N  -s  V  T  n) ,  the  program 
will  assume  that  the  input  command 

->V  T  N  V  T  n 

requires  six  input  values,  while  only  three  are  available.  The  result  would 
have  been  the  generation  of  an  error  message  and  the  interruption  of  the 
program  execution. 

To  include  the  subprogram  mentioned  above  in  the  modified  definition  of 
program  iSuiS,  will  require  you  to  use  L  J  «>>  at  the  beginning  and  end  of 
the  sub-program.  Because  the  program  symbols  occur  in  pairs,  whenever 
[  J  «>>  is  invoked,  you  will  need  to  erase  the  closing  program  symbol  f*  )  at 
the  beginning,  and  the  opening  program  symbol  («)  at  the  end,  of  the  sub- 
program. 
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To  erase  any  character  while  editing  the  program,  place  the  cursor  to  the  right 
of  the  character  to  be  erased  and  use  the  backspace  key  [  4  J . 

Store  the  program  back  into  variable  p  by  using  L  *i  jBffiiHil.    Next,  run  the 

program  by  pressing  111011.  Enter  values  of  V  =  0.01  m'^S,  T  =  300_K,  and  n 
=  0.8_mol,  v/hen  prompted.  Before  pressing  [inter]  for  input,  the  stack  will  look 
like  this: 


Enter  Vj T, and  n: 


V:0.01_m-^3 

T:300_K 

n:0.S_mol 


After  execution  of  the  program,  the  stack  will  look  like  this: 


4: 

V:(.01_m 

3: 

T:(300_K1 

Z: 

n:(.S_moi; 

P  = 

199543. 24_-^ 

In  summary:  The  common  thread  in  the  three  examples  shown  here  is  the 
use  of  tags  to  identify  input  and  output  variables.  If  we  use  an  input  string  to 
get  our  input  values,  those  values  are  already  pre-tagged  and  can  be  easily 
recall  into  the  stack  for  output.  Use  of  the  — >TAG  command  allows  us  to 
identify  the  output  from  a  program. 


Using  a  message  box 

A  message  box  is  a  fancier  way  to  present  output  from  a  program.  The 
message  box  command  in  the  calculator  is  obtained  by  using 
I  *i  J^gg_  [w^rJiLLnjji  SI!a3j3i.     The  message  box  command  requires  that  the 


output  string  to  be  placed  in  the  box  be  available  in  stack  level  1 .  To  see  the 

operation  of  the  MSGBOX  command  try  the  following  exercise: 

C3  CS  (3  S^l  SD     CTD  GD  CZD 

CED  ^  (^(33)(g(^(33g](^C5D(g) 

(3]fflG_  (W]SEIia  IGSIEE! 
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The  result  is  the  following  message  box: 


4-- 

3: 

0:  1.2_rad 

2: 

l: 

"0: 

1 . 2_rad4 

Press  ISuQIS  to  cancel  the  message  box. 

You  could  use  a  message  box  for  output  from  a  program  by  using  a  tagged 
output,  converted  to  a  string,  as  the  output  string  for  MSGBOX.  To  convert 
any  tagged  result,  or  any  algebraic  or  non-tagged  value,  to  a  string,  use  the 
function  ^STR  available  at  I3D«?5_  SffiE5!^!n3. 

Using  a  message  box  for  program  output 

The  function  SSuB,  from  the  last  example,  can  be  modified  to  read: 

«  "Enter  V,  T  and  n:  "  {"-'  :¥:<-'  ■.T:*-'  :n:  "  {2  0}  V  } 
INPUT  OBJ^  ->V  T  n  -s  V  T  n 

'  (8  .31451_J/ (K*mol)  )  *  (n*T/V) '  EVAL  "p"  ^TAG  ^STR  MSGBOX  S- 

;s- 

Store  the  program  back  into  variable  p  by  using  Run  the  program 

by  pressing  illililll.  Enter  values  of  V  =  0.01_m'^3,  T  =  300_K,  and  n  = 
0.8_mol,  v/hen  prompted. 

As  in  the  earlier  version  of  ISTSS,  before  pressing  [inter)  for  input,  the  stack  will 
look  like  this: 

Enter  Vj  T^  and  n: 

:V:0.01_m-^3 
:T:300_K 

:n:0.S-[HQl  

HnjlMljlli[*iniTJg1^M^M 

The  first  program  output  is  a  message  box  containing  the  string: 
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Enter  Vj        and  n: 


'  19954S.24_J/m-' 
3' 


T  ■  ■_'   I  ■■. 

n:0.S_mol4 


Press  HulIBS  to  cancel  message  box  output.  The  stack  will  now  look  like  this: 


4: 

3: 

V:[.01_m 

2: 

T:(300_K: 

l: 

n:C.S_mol) 

Mint 

P  IFuncoiinpToi  1 

Including  input  and  output  in  a  message  box 

We  could  modify  the  program  so  that  not  only  the  output,  but  also  the  input,  is 
included  in  a  message  box.  For  the  case  of  program  SSi7SS,  the  modified 
program  will  look  like: 


«      Enter   V,    T   and   n:       {  :n:       {2    0}    V  } 

INPUT  OBJ^  T  n  «  V  ->STR  "•^   "  +  T  ^STR  "•^  "  +     n  ^STR 

"•^  "  +  '  (8  .  31451_J/ (K*mol)  )  *  {n*T/V) '  EVAL  "p"  ^TAG  ^STR  + 
+  +  MSGBOX  S-  S- 

Notice  that  you  need  to  odd  the  following  piece  of  code  after  each  of  the 
variable  names  V,  T,  and  n,  within  the  sub-program: 

^STR         "  + 

To  get  this  piece  of  code  typed  in  the  first  time  use: 

(3}ffiG_i3a3jil^HiilIICE)^'  CDCB 

Because  the  functions  for  the  TYPE  menu  remain  available  in  the  soft  menu 

keys,  for  the  second  and  third  occurrences  of  the  piece  of  code  (^STR 

+  )  within  the  sub-program  (i.e.,  after  variables  T  and  n,  respectively),  all  you 

need  to  use  is: 
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You  will  notice  that  after  typing  the  keystroke  sequence  L  r»  J  a  new  line  is 
generated  in  the  stack. 

The  last  modification  that  needs  to  be  included  is  to  type  in  the  plus  sign  three 
times  after  the  call  to  the  function  at  the  very  end  of  the  sub-program. 


Note:  The  plus  sign  {+)  in  this  program  is  used  to  concatenate  strings. 
Concatenation  is  simply  the  operation  of  joining  individual  character  strings. 


To  see  the  program  operating: 

•  Store  the  program  back  into  variable  p  by  using  I  <n  jlwSi. 

•  Run  the  program  by  pressing  111111. 

•  Enter  values  of  V  =  O.Ol.m'^S,  T  =  300_K,  and  n  =  0.8_mol,  when 
prompted. 

As  in  the  earlier  version  of  [  p  ],  before  pressing  [ENTER]  for  input,  the  stack 
will  look  like  this: 

Enter  Vj        and  n: 

:V:0.01_m-^3 
:T:300_K 

:n:0.S-[HQl  

HnjlMljlli[*iniTJg1^M^M 

The  first  program  output  is  a  message  box  containing  the  string: 


tnt 

:V:  '.01_m-^3' 
:T:  '300_K' 
jn:  '.S_mol' 

:V: 
:T: 
:n: 

'T9954S.24_J/rvi-^ 
3' 

Press  ISuQBS  to  cancel  message  box  output. 
Incorporating  units  within  a  program 

As  you  have  been  able  to  observe  from  all  the  examples  for  the  different 
versions  of  program  BuSS  presented  in  this  chapter,  attaching  units  to  input 
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values  may  be  a  tedious  process.  You  could  have  the  program  itself  attach 
those  units  to  the  input  and  output  values.  We  v/ill  illustrate  these  options  by 
modifying  yet  once  more  the  program  IHIil,  as  follows. 

Recall  the  contents  of  program  IHHII  to  the  stack  by  using  (.  r»  J ■■381,  and 

modify  them  to  look  like  this: 


Note:  I've  separated  the  program  arbitrarily  into  several  lines  for  easy 
reading.  This  is  not  necessarily  the  way  that  the  program  shows  up  in  the 
calculator's  stack.  The  sequence  of  commands  is  correct,  however.  Also, 
recall  that  the  character  does  not  show  in  the  stack,  instead  it  produces  a 
new  line. 


■s  "Enter  V,T,n   [S.I.]:"  {"<-■   :V:*-'   :  T :       :n:  "  {2  0}  V  } 
INPUT  OBJ^  T  n 

V  'l_m-^3'*     T  '1_K'  *     n  'l_mol'  *    ->  V  T  n 
«  V  "V"   ^TAG  ^STR         "  +  T  "T"   ^TAG  ^STR  "•^  "  +  n 
"n"  ^TAG  ->STR  "•^  "  + 

'  (8  .  31451_J/ (K*mol)  )  *  (n*T/V) '  EVAL  "p"  ->TAG  ->STR  +  +  + 

MSGBOX  »■  s- 

This  new  version  of  the  program  includes  an  additional  level  of  sub- 
programming  (i.e.,  a  third  level  of  program  symbols  «  and  some  steps 
using  lists,  i.e., 

V  'l_m^3'  *  {  }  +  T  '1_K'  *  +  n  'l_mol'  *  +  EVAL  T  n 

The  interpretation  of  this  piece  of  code  is  as  follows.  (We  use  input  string 
values  of  :V:0.01,  :T:300,  and  :n:0.8): 

1 .  V  :  The  value  of  V,  as  a  tagged  input  (e.g.,  V:0.01 )  is 

placed  in  the  stack. 

2.  'l_m^3'  :  The  S.I.  units  corresponding  to  V  are  then  placed  in 

stack  level  1 ,  the  tagged  input  for  V  is  moved  to 
stack  level  2. 

3.  *  :  By  multiplying  the  contents  of  stack  levels  1  and  2, 
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4.  T  'i_k'  * 

5.  n  'l_inol'  * 

6.  ->V  T  n 


we  generate  a  number  with  units  (e.g.,  0.01_m'^3), 
but  the  tag  is  lost. 

:Calculating  value  of  T  including  S.I.  units 

:  Calculating  value  of  n  including  units 

:  The  values  of  V,  T,  and  n,  located  respectively  in 
stack  levels  3,  2,  and  1 ,  are  passed  on  to  the  next 
level  of  sub-programming. 


To  see  this  version  of  the  program  in  action  do  the  following: 

•  Store  the  program  back  into  variable  p  by  using  [*-\][   p  ]. 

•  Run  the  program  by  pressing  [   p  ]. 

•  Enter  values  of  V  =  0.01,  T  =  300,  and  n  =  0.8,  when  prompted  (no  units 
required  now). 

Before  pressing  [inter]  for  input,  the  stack  will  look  like  this: 


Enter  V, 

T,n  [S.I.]: 

:V:0.01 

:T:300 

:n:0.S 

pn  |Func?| 

PRPl  1  CHPa  1  CHPl  |inFP3 

Press  [inter]  to  run  the  program.  The  output  is  a  message  box  containing  the 
string: 


Ent 

:V:  '.01_m-^3' 
:T:  '300_K' 
:n:  '.S_mol' 

:V: 
:T: 
:n: 

:p: 

'  199543.  24_J/m-^ 
3' 

Press  lluliiB  to  cancel  message  box  output. 
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Message  box  output  without  units 

Let's  modify  the  program  Bm  once  more  to  eliminate  the  use  of  units 
throughout  it.  The  unit-less  program  will  look  like  this: 

■s  "Enter  V,T,n    [S.I.]:"   {"<-'  -.l:^    :n:  "   {2  0}   V  } 

INPUT  OBJ^  T  n 

•s  V  DTAG     T  DTAG     n  DTAG  ^    V  T  n 

«  "v="   V  ->-STR  +  "<-'   "+    "T="    T    ^STR  +  "<-'  "  +  "n="      n  ^STR  + 
"  + 

'8.31451*n*T/V'  EVAL  ->-STR  "p="  SWAP  +  +  +  +  MSGBOX  'A'  S- 

And  when  run  with  the  input  data  V  =  0.01,  T  =  300,  and  n  =  0.8,  produces 
the  message  box  output: 


Enter  V,T,n  [S.I.]: 


V:0.01 

T:300 

n:0.S 


pn  |FUnC?|  PRPl  I  CHPa  I  CHPl 


Enter  V,T,n  [S.I.]: 


V=.01 
T=300. 
n=.S 

P=19954S.24 


V: 
T: 

n:0.S4 


Press  SuHBS  to  cancel  the  message  box  output. 


Relational  and  logical  operators 

So  far  we  have  worked  mainly  with  sequential  programs.  The  User  RPL 
language  provides  statements  that  allow  branching  and  looping  of  the 
program  flow.  Many  of  these  make  decisions  based  on  whether  a  logical 
statement  is  true  or  not.  In  this  section  we  present  some  of  the  elements  used 
to  construct  such  logical  statements,  namely,  relational  and  logical  operators. 


Relational  operators 

Relational  operators  are  those  operators  used  to  compare  the  relative  position 
of  two  objects.  For  example,  dealing  with  real  numbers  only,  relational 
operators  are  used  to  make  a  statement  regarding  the  relative  position  of  two 
or  more  real  numbers.  Depending  on  the  actual  numbers  used,  such  a 
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statement  can  be  true  (represented  by  the  numerical  value  of  1 .  in  the 
calculator),  or  false  (represented  by  the  numerical  value  of  0.  in  the  calculator). 

The  relational  operators  available  for  programming  the  calculator  are: 


Operator 

Meaning 

Example 

"is  equal  to" 

'x==2' 

"is  not  equal  to" 

'3^2' 

< 

"is  less  than" 

'm<n' 

> 

"is  greater  than" 

'10>a' 

> 

"is  greater  than  or  equal  to" 

'p>q' 

< 

"is  less  than  or  equal  to" 

'7<12' 

All  of  the  operators,  except  ==  (which  can  be  created  by  typing  LtLJ  ^ 

 ^  ),  are  available  in  the  keyboard.   They  are  also  available  in 

(3rDfflG_  yiiSallS. 

Two  numbers,  variables,  or  algebraics  connected  by  a  relational  operator 
form  a  logical  expression  that  can  take  value  of  true  (1 .),  false  (0.),  or  could 
simply  not  be  evaluated.   To  determine  whether  a  logical  statement  is  true  or 
not,  place  the  statement  in  stack  level  1,  and  press  EVAL  ((fv^^zj).  Examples: 

'2<10'  (jm),  result:  1.  (true) 

'2>10'  d^T],  result:  0.  (false) 
In  the  next  example  it  is  assumed  that  the  variable  m  is  not  initialized  (it  has 
not  been  given  a  numerical  value): 

'2==m' result:  '2==m' 
The  fact  that  the  result  from  evaluating  the  statement  is  the  same  original 
statement  indicates  that  the  statement  cannot  be  evaluated  uniquely. 

Logical  operators 

Logical  operators  are  logical  particles  that  are  used  to  join  or  modify  simple 
logical  statements.  The  logical  operators  available  in  the  calculator  can  be 
easily  accessed  through  the  keystroke  sequence:  I  *n  Jf^^g  [nxt}. 
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The  available  logical  operators  are:  AND,  OR,  XOR  (exclusive  or),  NOT,  and 
SAME.  The  operators  v/ili  produce  results  that  are  true  or  false,  depending  on 
the  truth-value  of  the  logical  statements  affected.  The  operator  NOT 
(negation)  applies  to  a  single  logical  statements.  All  of  the  others  apply  to 
two  logical  statements. 

Tabulating  all  possible  combinations  of  one  or  tv/o  statements  together  with 
the  resulting  value  of  applying  a  certain  logical  operator  produces  what  is 
called  the  truth  table  of  the  operator.  The  following  are  truth  tables  of  each  of 
the  standard  logical  operators  available  in  the  calculator; 


p 

NOTp 

1 

0 

0 

1 

P 

q 

p  AND  q 

1 

1 

1 

1 

0 

0 

0 

1 

0 

0 

0 

0 

P 

q 

p  ORq 

1 

1 

1 

1 

0 

1 

0 

1 

1 

0 

0 

0 

P 

q 

pXORq 

1 

1 

0 

1 

0 

1 

0 

1 

1 

0 

0 

0 
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The  calculator  includes  also  the  logical  operator  SAME.  This  is  a  non- 
standard logical  operator  used  to  determine  if  two  objects  are  identical.  If 
they  are  identical,  a  value  of  1  (true)  is  returned,  if  not,  a  value  of  0  (false)  is 
returned.  For  example,  the  follov/ing  exercise,  in  RPN  mode,  returns  a  value 
of  0: 

'SQ(2)'  ^  4  ^  SAME 

Please  notice  that  the  use  of  SAME  implies  a  very  strict  interpretation  of  the 
v/ord  "identical."  For  that  reason,  SQ(2)  is  not  identical  to  4,  although  they 
both  evaluate,  numerically,  to  4. 

Program  branching 

Branching  of  a  program  flov/  implies  that  the  program  makes  a  decision 
among  tv/o  or  more  possible  flow  paths.  The  User  RPL  language  provides  a 
number  of  commands  that  can  be  used  for  program  branching.  The  menus 
containing  these  commands  are  accessed  through  the  keystroke  sequence: 

This  menu  shows  sub-menus  for  the  program  constructs 


1^ 


CH^E  ^THRT   FOR      DO  HHILE 


The  program  constructs  IF.. .THEN.. ELSE. ..END,  and  CASE. ..THEN. ..END  will 
be  referred  to  as  program  branching  constructs.  The  remaining  constructs, 
namely,  START,  FOR,  DO,  and  WHILE,  ore  appropriate  for  controlling 
repetitive  processing  within  a  program  and  will  be  referred  to  as  program 
loop  constructs.  The  latter  types  of  program  constructs  are  presented  in  more 
detail  in  a  later  section. 

Branching  with  IF 

In  this  section  we  presents  examples  using  the  constructs  IF. ..THEN. ..END  and 
IF.. .THEN. ..ELSE. ..END. 
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The  IF.. .THEN.. .END  construct 

The  IF... THEN... END  is  the  simplest  of  the  IF  program  constructs.  The  general 
format  of  this  construct  is: 


IF  logical_statement  THEN  program_statements  END. 
The  operation  of  this  construct  is  as  follows: 

1 .  Evaluate  logical_statement. 

2.  If  logical_statement  is  true,  perform  program  _statements  and  continue 
program  flow  after  the  END  statement. 

3.  If  logical_statement  is  false,  skip  program_statements  and  continue 
program  flow  after  the  END  statement. 

To  type  in  the  particles  IF,  THEN,  ELSE,  and  END,  use: 

(  .    1  our     aff:ft«3Ta  I 


The  functions  ':!'!:!.:!':'::.'.!":!  ':!':: Y::Y!  ":!::':.':.'!!]  are  available  in  that  menu  to  be  typed 
selectively  by  the  user.  Alternatively,  to  produce  an  IF. ..THEN. ..END 
construct  directly  on  the  stack,  use: 

This  will  create  the  following  input  in  the  stack: 


With  the  cursor  ^  in  front  of  the  IF  statement  prompting  the  user  for  the  logical 
statement  that  will  activate  the  IF  construct  when  the  program  is  executed. 
Example:  Type  in  the  following  program: 

■s  ^  X  «  IF  'x<3'  THEN  EVAL  END  "Done"  MSGBOX  »  S- 
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and  save  it  under  the  name  'f  1 '.  Press  and  verify  that  variable  lluOB  is 
indeed  available  in  your  variable  menu.  Verify  the  following  results: 


0 

3.5 


Result:  0 
Result:  no  action 


1.2 
10 


Result:  1.44 
Result:  no  action 


These  results  confirm  the  correct  operation  of  the  IF. ..THEN. ..END  construct. 
The  program,  as  v/ritten,  calculates  the  function  fi{x)  =  x^,  if  x  <  3  (and  not 
output  otherwise). 

The  IF...THEN...ELSE...END  construct 

The  IF. ..THEN. ..ELSE. ..END  construct  permits  two  alternative  program  flow 
paths  based  on  the  truth  value  of  the  logical_statement.  The  general  format  of 
this  construct  is: 

IF  logical  statement  THEN  program  statements  if_true 


The  operation  of  this  construct  is  as  follows: 

1 .  Evaluate  logical_statement. 

2.  If  logical_statement  is  true,  perform  program  statements_if_true  and 
continue  program  flow  after  the  END  statement. 

3.  If  logical_statement  is  false,  perform  program  statements_if_false  and 
continue  program  flow  after  the  END  statement. 

To  produce  an  IF. ..THEN. ..ELSE. ..END  construct  directly  on  the  stack,  use: 


ELSE  program_statements_if_false  END. 


This  will  create  the  following  input  in  the  stack: 


IF  4 

THEN 
ELSE 
EHD 


Example:  Type  in  the  following  program; 
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•!;^x«  IF  'x<3'  THEN  'x^2'  ELSE  '1-x'  END  EVAL  "Done"  MSGBOX 


and  save  it  under  the  name  'f2'.  Press  jVAR }  and  verify  that  variable  II 
indeed  available  in  your  variable  menu.  Verify  the  following  results: 
0  ilJE:lii  Result:  0  1 .2  M^m  Result:  1 .44 

3.5  ISEEIS  Result:  -2.5      10  HSilS  Result:  -9 
These  results  confirm  the  correct  operation  of  the  IF. ..THEN. ..ELSE. ..END 
construct.  The  program,  as  written,  calculates  the  function 


/2W  = 


I    x^,if  x<3 
1 1-x,  otherwise 


Note:  For  this  particular  case,  a  valid  alternative  would  have  been  to  use  an 
IFTE  function  of  the  form:  'f2(x)  =  IFTE(x<3,x^2,1-x)'  

Nested  IF...THEN... ELSE.. .END  constructs 

In  most  computer  programming  languages  where  the  IF. ..THEN. ..ELSE. ..END 
construct  is  available,  the  general  format  used  for  program  presentation  is  the 
following: 

IF  logical_statement  THEN 

program_s tatements_if_  true 

ELSE 

program_statements_if_false 

END 

In  designing  a  calculator  program  that  includes  IF  constructs,  you  could  start 
by  writing  by  hand  the  pseudo-code  for  the  IF  constructs  as  shown  above. 
For  example,  for  program  BtB,  you  could  write 


IF  x<3  THEN 
ELSE 

1-x 

END 
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while  this  simple  construct  works  fine  when  your  function  has  only  two 
branches,  you  may  need  to  nest  IF. ..THEN. ..ELSE. ..END  constructs  to  deal 
with  function  with  three  or  more  branches.    For  example,  consider  the 
function 

,if  x<2) 
\-x,  if  3<  X  <5 
fi  (x)  =  \  sin(x),  if  5<x<3;r 
Qxp(x),if  3;r  <  X  <  15 
-  2,  elsewhere 

Here  is  a  possible  way  to  evaluate  this  function  using  IF...  THEN  ...  ELSE  .. 
END  constructs: 


IF  x<3  THEN 


ELSE 


IF  x<5  THEN 
1-x 

ELSE 

IF  x<37r  THEN 
sin(x) 


ELSE 


IF  x<15  THEN 
exp(x) 

ELSE 

-2 

END 


END 


END 


END 

A  complex  IF  construct  like  this  is  called  a  set  of  nested  IF  ...  THEN  ...  ELSE 
END  constructs. 


A  possible  way  to  evaluate  f3(x),  based  on  the  nested  IF  construct  shown 
above,  is  to  write  the  program: 
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•ii^x*   IF  'x<3'  THEN  'x^2'  ELSE   IF  'x<5'  THEN  '1-x'  ELSE  IF 
'x<3*7r'  THEN  'SIN(x)'  ELSE   IF  'x<15'  THEN  'EXP(x)'  ELSE  -2 
END  END  END  END  EVAL  JS-  S- 

Store  the  program  in  variable  MtM  and  try  the  following  evaluations: 

Result  2.25  (i.e.,  x^) 

Result:  6.25  (i.e.,  x^j 

Result  -3.2  (i.e.,  1-x) 

Result  -0.631  266...  (i.e.,  sin(x),  v/ith  x  in  radians) 

Result  162754.791419  (i.e.,  exp(x)) 

Result  -2.  (i.e.,  -2) 

The  CASE  construct 

The  CASE  construct  can  be  used  to  code  several  possible  program  flux  paths, 
as  in  the  case  of  the  nested  IF  constructs  presented  earlier.   The  general 
format  of  this  construct  is  as  follows: 

CASE 

Logical_statementi  THEN  program_statementSi  END 
Logical_statement2  THEN  program_statementS2  END 


Logical_statement  THEN  program_statements  END 

Def ault_program_statements  (optional) 

END 

When  evaluating  this  construct,  the  program  tests  each  of  the 
logical_statemenfs  until  it  finds  one  that  is  true.  The  program  executes  the 
corresponding  program_statemenfs,  and  passes  program  flow  to  the  statement 
following  the  END  statement. 

The  CASE,  THEN,  and  END  statements  are  available  for  selective  typing  by 
usmg  L  <n  J^g    n:;ij:L:iii  umiaji. 
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If  you  are  in  the  BRCH  menu,  i.e.,  (( jn^l pkg   l||i|;Sj)  you  can  use  the  following 
shortcuts  to  type  in  your  CASE  construct  (The  location  of  the  cursor  is 
indicated  by  the  symbol  ^  ): 

•  CjlJ"     '  Starts  the  case  construct  providing  the  prompts:  CASE 
*THEN  END  END 

•  CEDISEeH!:  Completes  a  CASE  line  by  adding  the  particles  THEN  M  END 

Example  -  program  f3(x)  using  the  CASE  statement 
The  function  is  defined  by  the  following  5  expressions: 

x^,  //  X  <  3 
1-x,  //3<x<5 
sin(x),  if  5  <  X  <37i 
exp(x),//  3;r  <  X  <  15 
-  2,  elsewhere 

Using  the  CASE  statement  in  User  RPL  language  we  can  code  this  function  as: 

^  X      CASE  'x<3'  THEN  'x^2' END  'x<5'  THEN  '1-x' END 
'x<3*7r'  THEN  'SIN(x)'  END  'x<15'  THEN  'EXP  (x)  '  END  -2  END 

EVAL 

Store  the  program  into  a  variable  called  luiEI.  Then,  try  the  following 
exercises: 


1.5 

hjEux 

Result: 

2.25  (i.e.,  x2) 

2.5 

!S.!E:n:::s! 

Result 

6.25  (i.e.,  x2) 

4.2 

iiEF:£:'a"a! 

Result 

-3.2  (i.e.,  1-x) 

5.6 

SSjiZS 

Result 

-0.631266...  (i.e.,  sin(x),  with  x  in  radians) 

12 

■IjESJ::! 

Result 

162754.791419  (i.e.,  exp(x)) 

23 

Result 

-2.  (i.e.,  -2) 

/3W  = 
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As  you  can  see,  f3c  produces  exactly  the  same  results  as  f3.  The  only 
difference  in  the  programs  is  the  branching  constructs  used.  For  the  case  of 
function  f3(x),  which  requires  five  expressions  for  its  definition,  the  CASE 
construct  may  be  easier  to  code  than  a  number  of  nested  IF  ...  THEN  ... 
ELSE  ...  END  constructs. 

Program  loops 

Program  loops  are  constructs  that  permit  the  program  the  execution  of  a 
number  of  statements  repeatedly.  For  example,  suppose  that  you  want  to 
calculate  the  summation  of  the  square  of  the  integer  numbers  from  0  to  n,  i.e., 


To  calculate  this  summation  all  that  you  have  to  do  is  use  the  LiU  ?  key 

within  the  equation  editor  and  load  the  limits  and  expression  for  the 
summation  (examples  of  summations  are  presented  in  Chapters  2  and  1 3). 
However,  in  order  to  illustrate  the  use  of  programming  loops,  we  will  calculate 
this  summation  with  our  own  User  RPL  codes.  There  are  four  different 
commands  that  can  be  used  to  code  a  program  loop  in  User  RPL,  these  are 
START,  FOR,  DO,  and  WHILE.  The  commands  START  and  FOR  use  an  index 
or  counter  to  determine  how  many  times  the  loop  is  executed.  The  commands 
DO  and  WHILE  rely  on  a  logical  statement  to  decide  when  to  terminate  a 
loop  execution.  Operation  of  the  loop  commands  is  described  in  detail  in  the 
following  sections. 

The  START  construct 

The  START  construct  uses  two  values  of  an  index  to  execute  a  number  of 
statements  repeatedly.  There  are  two  versions  of  the  START  construct: 
START... NEXT  and  START  ...  STEP.  The  START... NEXT  version  is  used  when 
the  index  increment  is  equal  to  1,  and  the  START. ..STEP  version  is  used  when 
the  index  increment  is  determined  by  the  user. 

Commands  involved  in  the  START  construct  are  available  through: 


n 


k=0 
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f  ,    \  oor     ■BbKiTB  iffPvymrx  rxmrxn 

L  *n  J  f^c    w:iiiaii  EUliiiiu  EUijii 

Within  the  BRCH  menu  (I  <n  Jfflg_  S^SallS)  the  following  keystrokes  are  available 
to  generate  START  constructs  (the  symbol  indicates  cursor  position): 

•  C5D  ISEEEEil        :  Starts  the  START.. .NEXT  construct:  START  * 
NEXT 

•  C3  IeEEEEI        :  Starts  the  start.. .step  construct:  start*  step 

The  START.. .NEXT  construct 

The  general  form  of  this  statement  is: 

start_value  end_value  START  program_statements  NEXT 

Because  for  this  case  the  increment  is  1 ,  in  order  for  the  loop  to  end  you 
should  ensure  that  start_value  <  end_value.  Otherwise  you  will 
produce  what  is  called  an  infinite  (never-ending)  loop. 

Example  -  calculating  of  the  summation  S  defined  above 
The  START... NEXT  construct  contains  an  index  whose  value  is  inaccessible  to 
the  user.  Since  for  the  calculation  of  the  sum  the  index  itself  (k,  in  this  case)  is 
needed,  we  must  create  our  own  index,  k,  that  we  will  increment  within  the 
loop  each  time  the  loop  is  executed.  A  possible  implementation  for  the 
calculation  of  S  is  the  program: 

■s  0.   DUP  S  k  «  0.   n  START  k  SQ  S  +  1 .   'k'  STO+  'S'  STO 

NEXT  S  "S"  ->TAG  S-  JS- 

Type  the  program  in,  and  save  it  in  a  variable  called  IIkE!!!. 

Here  is  a  brief  explanation  of  how  the  program  works: 

1 .   This  program  needs  an  integer  number  as  Input.  Thus,  before  execution, 
that  number  (n)  is  in  stack  level  1 .  The  program  is  then  executed. 
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2.  A  zero  is  entered,  moving  n  to  stack  level  2. 

3.  The  command  DUP,  which  can  be  typed  in  as  (^i™)(^t^(g](gl(g(^i™), 
copies  the  contents  of  stack  level  1 ,  moves  all  the  stack  levels  upwards, 
and  places  the  copy  just  made  in  stack  level  1 .  Thus,  after  DUP  is 
executed,  n  is  in  stack  level  3,  and  zeroes  fill  stack  levels  1  and  2. 

4.  The  piece  of  code  ->  n  s  k  stores  the  values  of  n,  0,  and  0,  respectively 
into  local  variables  n,  S,  k.  We  say  that  the  variables  n,  S,  and  k  have 
been  initialized  (S  and  k  to  zero,  n  to  whatever  value  the  user  chooses). 

5.  The  piece  of  code  0  .  n  START  identifies  a  START  loop  whose  index 
will  take  values  of  0,  1,  2,  n 

6 .  The  sum  S  is  incremented  by  k^  in  the  piece  of  code  that  reads:  k  SQ  S 


7  .  The  index  k  is  incremented  by  1  in  the  piece  of  code  that  reads:  1 .  k  + 

8.  At  this  point,  the  updated  values  of  S  and  k  are  available  in  stack  levels  2 
and  1,  respectively.  The  piece  of  code  'k'  STO  stores  the  value  from 
stack  level  1  into  local  variable  k.  The  updated  value  of  S  now  occupies 
stack  level  1 . 

9.  The  piece  of  code  'S'  STO  stores  the  value  from  stack  level  1  into  local 
variable  k.  The  stack  is  now  empty. 

10.  The  particle  NEXT  increases  the  index  by  one  and  sends  the  control  to 
the  beginning  of  the  loop  (step  6). 

1 1 .  The  loop  is  repeated  until  the  loop  index  reaches  the  maximum  value,  n. 

1 2.  The  last  part  of  the  program  recalls  the  last  value  of  S  (the  summation), 
tags  it,  and  places  it  in  stack  level  1  to  be  viewed  by  the  user  as  the 
program  output. 

To  see  the  program  in  action,  step  by  step,  you  can  use  the  debugger  as 
follows  (use  n  =  2).  Let  SLl  mean  stack  level  1 : 


+ 


CW)CTD[']SEI3S 


Place  a  2  in  level  2,  and  the 

program  name,  'ST,  in  level  1 

Start  the  debugger.  SLl  =2. 

SLl  =0.,  SL2  =  2. 

SLl  =  0.,  SL2  =  0.,  SL3  =  2.  (DUP) 

Empty  stack  (->  n  S  k) 

Empty  stack  (s  ■  start  subprogram) 
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KKXn  1  II 

SLl  =  0.,  (start  value  of  loop  index) 

man  1  ii 

SLl  =  2.(n),  SL2  =  0.  (end  value  of  loop 

index) 

KKXn  1  II 

Empty  stack  (START  -  beginning  of  loop) 

-  loop  execution 

number  1  for  k  =  0 

man  1  p 

SLl  =  0.  (k) 

flaara  1  ii 

SLl  =  0.  (SQ(k)  =  k^) 

aaan  1  ii 

■::9::9ui4'ii 

SLl  =  0.(S),  SL2  =  0.  (k2) 

Baara  1  ii 

SLl  =  0.  (S  +  k^) 

man  1  ii 

SLl  =  1.,  SL2  =  0.  (S  +  k^) 

man  1  ii 

SLl  =  0.(k),  SL2  =  1.,  SL3  =  0.  (S  +  k^) 

■■nars  1  ii 

SLl  =  l.(k+l),  SL2  =  0.  (S  +  k^) 

SLl  ='k',  SL2  =  1.,  SL3  =  0.  (S  +  k^) 

S§§[i4'll 

SLl  =  0.  (S  +  k^)  [Stores  value  of  SL2  =  1, 

into  SLl  =  'k'] 

man  1  ii 

SLl  =  'S',  SL2  =  0.  (S  +  k^) 

man  1  ii 

Empty  stock  [Stores  value  of  SL2  =  0,  into 

SLl  =  'S'] 

man  1  u 

Empty  stack  (NEXT  -  end  of  loop) 

-  loop  execution 

number  2  for  k  =  1 

SLl  =  1.  (k) 

man  1  ii 
■::9::9U>1'II 

SLl  =  1.  (SQ(k)  =  k^) 

SSSlill 

SLl  =  0.(S),  SL2  =  1 .  (k^) 

man  1  ii 

SLl  =  1 .  (S  +  k^) 

man  1  ii 

SLl  =  1 .,  SL2  =  1 .  (S  +  k^) 

man  1  ii 

SLl  =  l.(k),  SL2  =  1.,  SL3  =  1.  (S  +  k^) 

man  1  ii 

SLl  =  2.(k+l),  SL2  =  1.  (S  +  k2) 

i§§ij4'll 

SLl  =  'k',  SL2  =  2.,  SL3  =  1.  (S  +  k^) 

man  1  ii 

SLl  =  1 .  (S  +  k^)  [Stores  value  of  SL2  =  2, 

into  SLl  =  'k'] 

man  1  ii 

SLl  =  'S',  SL2  =  1.  (S  +  k^) 

man  1  ii 

Empty  stack  [Stores  value  of  SL2  =  1,  into 

SLl  =  'S'] 
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KKXn  1  II 

Empty  stock  (NEXT  -  end  of  loop) 

—  loop  execution  number  3  for  k 

=  2 

naara  1  ii 

SLl  =  2.  (k) 

giaiara^i! 

SLl  =  4.  (SQ(k)  =  k^) 

SLl  =  l.(S),  SL2  =  4.  (k2) 

SLl  =  5.  (S  +  k^) 

flaara  1  ii 

SLl  =  1.,  SL2  =  5.  (S  +  k2) 

VDKXn  1  II 

SLl  =  2.(k),  SL2  =  1.,  SL3  =  5.  (S  +  k^) 

Baara  1  ii 

SLl  =  3.(k+l),  SL2  =  5.  (S  +  k^) 

laars  1  ii 

SLl  =  'k',  SL2  =  3.,  SL3  =  5.  (S  +  k^) 

SLl  =  5.  (S  +  k^)  [Stores  value  of  SL2  =  3, 

into  SLl  =  'k'] 

mm 

SLl  =  'S',  SL2  =  5.  (S  +  k2) 

S§§[i4'll 

Empty  stock  [Stores  value  of  SL2  =  0,  into 

SLl  =  'S'] 

laara  1  ii 

Empty  stack  (NEXT  -  end  of  loop) 

--  for  n  =  2,  tfie  loop  index  is  exfiausted  and  control  is  passed  to  tfie  statement 
following  NEXT 


s'y.~.~^~  SLl  =5  (S  is  recalled  to  the  stack) 

miU  SLl  =  "S",  SL2  =  5  ("S"  is  placed  in  tfie 

stack) 

miV«  SLl  =  S:5  (tagging  output  value) 

miV«  SLl  =  S:5  (leaving  sub-program  :*  ) 

liaHj^ll  SLl  =  S:5  (leaving  main  program  '■^) 


The  step-by-step  listing  is  finished.  The  result  of  running  program  EEB  with  n 
=  2,  is  S:5. 


Check  also  the  following  results: 

3  SESIS  Result:  S:14 

5  n'H"!  Result:  S  :  55 

10  Result:  S:385 

30  i-in-i  Result:  S:  9455 


4  SeuS  Result:  S:30 
8  lEIEii  Result:  S:204 
20  lllil  Result:  S:2870 
lOOs^iil  Result:  S:  338350 
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The  START... STEP  construct 

The  general  form  of  this  statement  is: 

start_value  end_value  START  program_statements  increment 
NEXT 

The  start_value,  end_value,  and  increment  of  the  loop  index  can  be 
positive  or  negative  quantities.  For  increment  >  0,  execution  occurs  as 
long  as  the  index  is  less  than  or  equal  to  end  value.  For  increment  <  0, 
execution  occurs  as  long  as  the  index  is  greater  than  or  equal  to  end_value. 

Example  -  generating  a  list  of  values 

Suppose  that  you  want  to  generate  a  list  of  values  of  x  from  x  =  0.5  to  x  = 
6.5  in  increments  of  0.5.  You  can  v^rite  the  follov^ing  program: 

■s  ->  xs  xe  dx  «  xs  DUP  xe  START  DUP  dx  +  dx  STEP  DROP  xe 
xs  -  dx  /  ABS   1  +  ^LIST  S- 

and  store  it  in  variable  nHHiEEil. 

In  this  program  ,  xs  =  starting  value  of  the  loop,  xe  =  ending  value  of  the  loop, 
dx  =  increment  value  for  loop.  The  program  places  values  of  xs,  xs+dx, 
xs+2-dx,  xs+3-dx,  ...  in  the  stack.  Then,  it  calculates  the  number  of  elements 
generated  using  the  piece  of  code:      xe  xs  -  dx  /  ABS  1 .  + 

Finally,  the  program  puts  together  a  list  with  the  elements  placed  in  the  stack. 

•     Check  out  that  the  program  call  0.5  [inter]  2.5  [enter)  0.5  [inter]  liiMaS 


produces  the  list  {0.5  1 .  1 .5  2.  2.5}. 
•    To  see  step-by-step  operation  use  the  program  DBUG  for  a  short  list,  for 


example: 


[  VAR  J  1  [  SPC  ]  1  .5  [  SPC  ]  0.5  [enter] 
[     J  UrUU  [ENTER] 

(33fflG_  JEM  EQ3 


Enter  parameters  1   1 .5  0.5 
Enter  the  program  name  in  level  1 
Start  the  debugger. 
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Use  E-EuJ'i  to  step  into  the  program  and  see  the  detailed  operation  of  each 
command. 

The  FOR  construct 

As  in  the  case  of  the  START  command,  the  FOR  command  has  two  variations: 
the  FOR. ..NEXT  construct,  for  loop  index  increments  of  1,  and  the  FOR. ..STEP 
construct,  for  loop  index  increments  selected  by  the  user.  Unlike  the  START 
command,  however,  the  FOR  command  does  require  that  we  provide  a  name 
for  the  loop  index  (e.g.,  j,  k,  n).   We  need  not  to  worry  about  incrementing 
the  index  ourselves,  as  done  in  the  examples  using  START.  The  value 
corresponding  to  the  index  is  available  for  calculations. 

Commands  involved  in  the  FOR  construct  are  available  through: 


Within  the  BRCH  menu  ([ jn_l lill?|S|T|ll)  the  following  keystrokes  ore  available 
to  generate  FOR  constructs  (the  symbol  ^  indicates  cursor  position): 

•  C5D  S133:  Starts  the  FOR.. .NEXT  construct:  FOR  *  NEXT 

•  CED  "133:  Starts  the  FOR... STEP  construct:  FOR  *  STEP 

The  FOR.. .NEXT  construct 

The  general  form  of  this  statement  is: 

start_value  end._value  FOR  loop_index  program_statements 
NEXT 

To  avoid  an  infinite  loop,  make  sure  that  start_value  <  end_value. 

Example  -  calculate  the  summation  S  using  a  FOR... NEXT  construct 
The  following  program  calculates  the  summation 


n 


k=0 
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Using  a  FOR.. .NEXT  loop: 


■sO-^nS-sOn  FOR  k  k  SQ  S  +  'S'  STO  NEXT  S  "S"  -^TAG  S-  J> 
Store  this  program  in  a  variable  ElB.  Verify  the  following  exercises:  I  vm  J 


You  may  have  noticed  that  the  program  is  much  simpler  than  the  one  stored  in 
SS§!3S.  There  is  no  need  to  initialize  k,  or  to  increment  k  v/ithin  the  program. 
The  program  itself  takes  care  of  producing  such  increments. 

The  FOR... STEP  construct 

The  general  form  of  this  statement  is: 

startvalue  end_value  FOR  loop_index  program_statements 
increment  STEP 

The  start_value,  end_value,  and  increment  of  the  loop  index  can  be 
positive  or  negative  quantities.  For  increment  >  0,  execution  occurs  as 
long  as  the  index  is  less  than  or  equal  to  end_value.  For  increment  <  0, 
execution  occurs  as  long  as  the  index  is  greater  than  or  equal  to  end_value. 
Program  statements  are  executed  at  least  once  (e.g.,  l  0  start  l  l  step 
returns  1) 

Example  -  generate  a  list  of  numbers  using  a  FOR... STEP  construct 
Type  in  the  program: 

■s  — >  xs  xe  dx  s  xe  xs  -  dx  /  ABS  1 .   +  — >  n  -s  xs  xe  FOR  x 
X  dx  STEP  n  ->-LIST  S-  ^^  S- 

and  store  it  in  variable  IBHiEtl. 


Result:  S:14 
Result:  S:55 
Result:  S:385 


4  llill  Result:  S:30 
8  iig^iy  Result:  S:204 
20  lEai  Result:  S:2870 
100  8!i3 Result:  S:  338350 


Result:  S:  94  55 
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•  check  out  that  the  program  call  0.5  [wraj  2.5  [iNTst}  0.5  [enter)  E3S3i3 
produces  the  list  {0.5  1 .  1 .5  2.  2.5}. 

•  To  see  step-by-step  operation  use  the  program  DBUG  for  a  short  list,  for 
example: 


[  VM  J  1  [  SPC  J    1  .5  I.  SPC  }   0.5  [enter) 

niBSlEK^ 

(33fflG_  (W](W)  asm!!  SEEE3 


Enter  parameters  1   1 .5  0.5 
Enter  the  program  name  in  level  1 
Start  the  debugger. 


Use  lEEijl>l'll  to  step  into  the  program  and  see  the  detailed  operation  of  each 
command. 


The  DO  construct 

The  general  structure  of  this  command  is: 

DO  program  statements  UNTIL  logical  statement  END 
The  DO  command  starts  an  indefinite  loop  executing  the  program_statements 
until  the  logical_statement  returns  FALSE  (0).  The  logical_statement  must 
contain  the  value  of  an  index  whose  value  is  changed  in  the 

program_statements. 

Example  1  -  This  program  produces  a  counter  in  the  upper  left  corner  of  the 
screen  that  adds  1  in  an  indefinite  loop  until  a  keystroke  (press  any  key)  stops 
the  counter:  «  0  DO  DUP  1  DISP  1  +  UNTIL  KEY  END  DROP  S- 

Command  KEY  evaluates  to  TRUE  when  a  keystroke  occurs. 

Example  2  -  calculate  the  summation  S  using  a  DO... UNTIL... END  construct 
The  following  program  calculates  the  summation 

n 

Using  a  DO.. .UNTIL.. .END  loop: 

«  0.   ^   n  S       DO  n  SQ  S  +  'S'  STO  n  1  -  'n'  STO  UNTIL 
'n<0'  END  S  "S"  ->TAG  S- 
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Store  this  program  in  a  variable  ^§11! 


I.  Verify  the  following  exercises:  C^T) 


3  SElaS  Result:  S:14 

5  lllllll  Result:  S  :  55 

10  liil  Result:  S:385 

30  lis  Result:  S:9455 


4  SEiS!  Result:  S:30 
8  liiii  Result:  S:204 
20  liiii  Result:  S:2870 
IOOIesI  Result:  S:  338350 


Example  3  -  generate  a  list  using  a  DO... UNTIL... END  construct 
Type  in  the  following  program 

■s  — >  xs  xe  dx  -s  xe  xs  -  dx  /  ABS  1 .  +  xs  — >  n  x  -s  xs  DO 
'x+dx'    EVAL  DUP    'x'    STO  UNTIL    ''x>xe'    END  n  ^LIST  JS-  S-  S- 

and  store  it  in  variable  lEullLiEilEil. 

•     Check  out  that  the  program  call  0.5  [fwaj  2.5  [inter]  0.5  [inter}  fSSxa 


produces  the  list  {0.5  1 .  1 .5  2.  2.5}. 
•    To  see  step-by-step  operation  use  the  program  DBUG  for  a  short  list,  for 


Use  IeeiIIJ'II  to  step  into  the  program  and  see  the  detailed  operation  of  each 
command. 

The  WHILE  construct 

The  general  structure  of  this  command  is: 

WHILE  logical_statement  REPEAT  program_statements  END 

The  WHILE  statement  will  repeat  the  prograin_statements  while 
logical  statement  is  true  (non  zero).  If  not,  program  control  is  passed  to 
the  statement  right  after  END.  The  program_statements  must  include  a 


example: 


[  VAR  J  1  [  SPC  }    1  .5  I.  SPC  }   0.5  [enter] 


Enter  parameters  1   1 .5  0.5 
Enter  the  program  name  in  level  1 
Start  the  debugger. 
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loop  index  that  gets  modified  before  the  logical  statement  is  checked  at 
the  beginning  of  the  next  repetition.  Unlike  the  DO  command,  if  the  first 
evaluation  of  logical_statement  is  false,  the  loop  is  never  executed. 

Example  1  -  calculate  the  summation  S  using  a  WHILE. ..REPEAT.. .END 
construct 

The  following  program  calculates  the  summation 


^2 

k=0 


Using  a  WHILE. ..REPEAT.. .END  loop: 

«  0.            S  -s  WHILE  'n>0'  REPEAT  n  SQ  S  +  'S'  STO  n  1  - 
'n'  STO  END  S  "S"  ^TAG  » 

Store  this  program  in  a  variable  taSSSi.  Verify  the  follov/ing  exercises:  I  vm  J 

3  ma           Result:  S:  14                   4  WSM  Result:  S:30 

5  SEIIjS           Result:  S:  55                   8  SEllS  Result:  S:  204 

1 0  liililjlll           Result:  S  :  3  8 5               20  llllilill  Result:  S  :  2  8 7  0 

30  mm           Result:  S:9455            100  EDI  Result:  S:  338350 


Example  2  -  generate  a  list  using  a  WHILE. ..REPEAT. ..END  construct 
Type  in  the  follov/ing  program 

■s  — >  xs  xe  dx  -s  xe  xs  -  dx  /  ABS  1 .   +  xs  — >  n  x  -s  xs 
WHILE  'x<xe' REPEAT  'x+dx'  EVAL  DUP  'x'  STO  END  n  ^LIST  S- 

and  store  it  in  variable  ll£lH!§i!l. 

•  Check  out  that  the  program  call  0.5  [waj  2.5        0.5  [inter]  SaSau 
produces  the  list  {0.5  1 .  1 .5  2.  2.5}. 

•  To  see  step-by-step  operation  use  the  program  DBUG  for  a  short  list,  for 
example: 
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[  m  J 1  [  spc  J  1 .5  I.  spc  J  0.5  (fWH) 

[']IEKi§:i(^ 

(3)fflG_  S3IIIIS  iEIiu 


Enter  parameters  1   1 .5  0.5 
Enter  the  program  name  in  level  1 
Start  the  debugger. 


Use  lEElijl4'll  to  step  into  the  program  and  see  the  detailed  operation  of  each 
command. 

Errors  and  error  trapping 

The  functions  of  the  PRG/ERROR  sub-menu  provide  ways  to  manipulate  errors 
in  the  calculator,  and  trap  errors  in  programs.   The  PRG/ERROR  sub-menu, 
available  through  I  *i  JfflG_  (W)(W][IaaI3l ,  contains  the  follov/ing  functions 
and  sub-menus: 


DOERRI  ERRn  |  ERRH  |  ERRD  |LH£TH|IFERR 


DOERR 

This  function  executes  an  user-define  error,  thus  causing  the  calculator  to 
behave  as  if  that  particular  error  has  occurred.  The  function  can  take  as 
argument  either  an  integer  number,  a  binary  integer  number,  an  error 
message,  or  the  number  zero  (0).  For  example,  in  RPN  mode,  entering 
[  5  jliNTEK]  iillylilii,  produces  the  following  error  message:  Error:  Memory  Clear 

If  you  enter  #1 1  h  Q^m}  [jllaaa,  produces  the  following  message:  Error: 
Undefined  FPTR  Name 

If  you  enter  "TRY  AGAIN"  [inter]  133133,  produces  the  following  message:  TRY 
AGAIN 

Finally,  I  0  ][enter)  EEIiijH,  produces  the  message:  Interrupted 


ERRN 

This  function  returns  a  number  representing  the  most  recent  error.  For 
example,  if  you  try  I  0  Jl  '/» Jl  ow  jlCEEEl,  you  get  the  number  #305h.  This  is  the 
binary  integer  representing  the  error:  Infinite  Result 
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ERRM 


This  function  returns  a  character  string  representing  the  error  message  of  the 
most  recent  error.  For  example,  in  Approx  mode,  if  you  try  1.  0  J[    J[  o/v  jUjCEii], 
you  get  the  following  string:  "Infinite  Result" 


This  function  clears  the  last  error  number,  so  that,  executing  ERRN  afterwards, 
in  Approx  mode,  will  return  #  Oh.  For  example,  if  you  try 
(^JCSCo^DiiMiJI  lljiEEIII,  you  get  #  Oh.   Also,  if  you  try 
(XDISChDII^EEEISEIII,  you  get  the  empty  string  "  ". 


This  function  returns  copies  of  the  arguments  of  the  command  or  function 
executed  most  recently.  For  example,  in  RPN  mode,  if  you  use: 
CJJC±DCID^,  and  then  use  function  LASTARG  (SMEI),  you  will  get  the 
values  3  and  2  listed  in  the  stack.  Another  example,  in  RPN  mode,  is  the 
following:   I  5  K  tan  j[w7h).  Using  LASTARG  after  these  entries  produces  a  5. 

Sub-menu  IFERR 

The  133333  sub-menu  provides  the  following  functions: 


These  are  the  components  of  the  IFERR  ...  THEN  ...  END  construct  or  of  the 
IFERR  ...  THEN  ...  ELSE  ...  END  construct.    Both  logical  constructs  are  used 
for  trapping  errors  during  program  execution.   Within  the  EiSalS  sub-menu, 
entering  CjT]llLiljil-ilj!lj!l,  or  CrfD'.''"  ",  will  place  the  IFERR  structure  components  in 
the  stack,  ready  for  the  user  to  fill  the  missing  terms,  i.e., 

n  I  lFERR~4 


ERRO 


LASTARG 


IFERR  4 
THEN 

EHD 


THEN 
ELSE 
EHD 


The  general  form  of  the  two  error-trapping  constructs  is  as  follows: 
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IF  trap-clause  THEN  error-clause  END 

IF  trap-clause  THEN  error-clause  ELSE  normal-clause  END 

The  operation  of  these  logical  constructs  is  similar  to  that  of  the  IF  ...  THEN  ... 
END  and  of  the  IF  ...  THEN  ...  ELSE  ...  END  constructs.  If  an  error  is 
detected  during  the  execution  of  the  trap-clause,  then  the  error-clause  is 
executed.  Otherwise,  the  normal-clause  is  executed. 

As  an  example,  consider  the  following  program  (EaSSj)  that  takes  as  input  two 

matrices,  A  and  b,  and  checks  if  there  is  an  error  in  the  trap  clause:  A  b  / 
(RPN  mode,  i.e.,  A/b).  If  there  is  an  error,  then  the  program  calls  function 
LSQ  (Least  SQuares,  see  Chapter  1 1 )  to  solve  the  system  of  equations: 

■s   ^  A  b  -s   IFERR  A  b  /  THEN  LSQ  END  S- 

Try  it  with  the  arguments  A  =  [  [  2,  3,  5  ]  ,  [1 ,  2,  1  ]  ]  and  b  =  [  [  5  ]  ,  [  6  ]  ]. 
A  simple  division  of  these  two  arguments  produces  an  error:  /Error:  Invalid 
Dimension. 

However,  with  the  error-trapping  construct  of  the  program,  SMi,  with  the 
same  arguments  produces:  [0.262295...,  0.442622...]. 

User  RPL  programming  in  algebraic  mode 

While  all  the  programs  presented  earlier  are  produced  and  run  in  RPN  mode, 
you  can  always  type  a  program  in  User  RPL  when  in  algebraic  mode  by  using 
function  RPL>.  This  function  is  available  through  the  command  catalog.  As 
an  example,  try  creating  the  following  program  in  algebraic  mode,  and  store 
it  into  variable  P2:  -s  ^  X  '2.5-3*X^2' 

First,  activate  the  RPL>  function  from  the  command  catalog  ((j^l  cat  ).  All 
functions  activated  in  ALG  mode  have  a  pair  of  parentheses  attached  to  their 
name.  The  RPL>  function  is  not  exception,  except  that  the  parentheses  must  be 
removed  before  we  type  a  program  in  the  screen.  Use  the  arrow  keys 
(<3DCE5)  and  the  delete  key  ([  4  J)  to  eliminate  the  parentheses  from  the  RPL>() 
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statement.  At  this  point  you  will  be  ready  to  type  the  RPL  program.  The 
following  figures  show  the  RPL>  command  with  the  program  before  and  after 
pressing  the  Q^ja}  key. 


RPL> 

«      X  '2.5-3*X-^2' 

:          X  '2.5-3*X-^2'  s- 
■s      X  '2.5-3*X-^2'  » 

To  store  the  program  use  the  STO  command  as  follows: 


:  -s      X  '£.5-3*X-^2'  s- 

■s      X  '2.5-3*X-^2'  » 
:flHS(l)^P2 

An  evaluation  of  program  P2  for  the  argument  X  =  5  is  shown  in  the  next 
screen: 


:  P2(5) 

-72.5 

While  you  can  write  programs  in  algebraic  mode,  without  using  the  function 
RPL>,  some  of  the  RPL  constructs  will  produce  an  error  message  when  you 
press  IwfflJ ,  for  example:   


A  In^^al  id 
Syntax 

«  1 

3  ass  j  j  1  +  HEX,,, 

Whereas,  using  RPL,  there  is  no  problem  when  loading  this  program  in 
algebraic  mode: 


RPL> 

:       1  3  FOR  j  j  1  + 

*:  1  3  FOR  j  j   1  +  HEX.., 

^EXT  s- 

s  1  3  FOR  j  j  1  +  HEXT 
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Chapter  22 

Programs  for  graphics  manipulation 

This  chapter  includes  a  number  of  examples  showing  how  to  use  the 
calculator's  functions  for  manipulating  graphics  interactively  or  through  the 
use  of  programs.  As  in  Chapter  21  we  recommend  using  RPN  mode  and 
setting  system  flag  1 17  to  SOFT  menu  labels.  -^K 

We  introduce  a  variety  of  calculator  graphic  applications  in  Chapter  1  2. 
The  examples  of  Chapter  1  2  represent  interactive  production  of  graphics 
using  the  calculator's  pre-programmed  input  forms.    It  is  also  possible  to  use 
graphs  in  your  programs,  for  example,  to  complement  numerical  results  with 
graphics.   To  accomplish  such  tasks,  we  first  introduce  function  in  the  PLOT 
menu. 

The  PLOT  menu 

Commands  for  setting  up  and  producing  plots  are  available  through  the  PLOT 
menu.  You  can  access  the  PLOT  menu  by  using;  [  8  ][  I  }[  '  )[  0  )CT1 
(3)fflG_  (W]||!EEI]EI  EEEE5  lEami. 

i=  I 
5: 

Eq: 

Ptype:  FUNCTION 


pfVPE[  PPAR  I   EC   |ERH£E|  DRHX  |  DRHH 


The  menu  thus  produced  provides  the  user  access  to  a  variety  of  graphics 
functions.  For  application  in  subsequent  examples,  let's  user-define  the  flH 
(GRAPH)  key  to  provide  access  to  this  menu  as  described  below. 

User-defined  key  for  the  PLOT  menu 

Enter  the  following  keystrokes  to  determine  whether  you  have  any  user-defined 
keys  already  stored  in  your  calculator;  IjT]™^  (W]Eiiiia3  iilliiEi  mMSS. 
Unless  you  have  user-defined  some  keys,  you  should  get  in  return  a  list 
containing  an  S,  i.e.,  {S}.  This  indicates  that  the  Standard  keyboard  is  the 
only  key  definition  stored  in  your  calculator. 
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To  user-define  a  key  you  need  to  add  to  this  list  a  command  or  program 
followed  by  a  reference  to  the  key  (see  details  in  Chapter  20).  Type  the  list 
■•.  S  <<  81  ::f!il  MENU  ■■■>  I3::f:i  }  in  the  stack  and  use  function 
STOKE YS  ((:S™^C^i:Ei^iani!^^i^iii3^^^^  as  the 

access  to  the  PLOT  menu.  Verify  that  such  list  was  stored  in  the  calculator  by 
using  (jT]™g_  (W]||T|M1I  lillllii  illlillili. 


Note:  We  will  not  work  any  exercise  while  presenting  the  PLOT  menu,  its 
functions  or  sub-menus.  This  section  will  be  more  like  a  tour  of  the  contents  of 
PLOT  as  they  relate  to  the  different  type  of  graphs  available  in  the  calculator. 


To  activate  a  user  defined  key  you  need  to  press  [^^^user_  (same  as  the 


[alpha)  key)  before  pressing  the  key  or  keystroke  combination  of  interest.  To 
activate  the  PLOT  menu,  with  the  key  definition  used  above,  press:  [^^user_ 
(jL)  ■  You  will  get  the  following  menu  (press  (nxT)  to  move  to  second  menu) 


PTYPE  PPHR     EC    ERHfE  DRHX  DRHH 


STflT   FLAG  LflREL  flUTO  IRFO 


Description  of  the  PLOT  menu 

The  following  diagram  shows  the  menus  in  PLOT.  The  number  accompanying 
the  different  menus  and  functions  in  the  diagram  are  used  as  reference  in  the 
subsequent  description  of  those  objects. 


The  soft  menu  key  labeled  3D,  STAT,  FLAG,  PTYPE,  and  PPAR,  produce 
additional  menus,  which  will  be  presented  in  more  detail  later.  At  this  point 
we  describe  the  functions  directly  accessible  through  soft  menu  keys  for  menu 
number  81 .02.  These  are: 
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LABEL  (10) 

The  function  LABEL  is  used  to  label  the  axes  in  a  plot  including  the  variable 
names  and  minimum  and  maximum  values  of  the  axes.  The  variable  names 
are  selected  from  information  contained  in  the  variable  PPAR. 


AUTO  (11) 

The  function  AUTO  (AUTOscale)  calculates  a  display  range  for  the  y-axis  or 
for  both  the  x-  and  y-axes  in  two-dimensional  plots  according  to  the  type  of 
plot  defined  in  PPAR.  For  any  of  the  three-dimensional  graphs  the  function 
AUTO  produces  no  action.  For  two-dimensional  plots,  the  following  actions 
are  performed  by  AUTO: 

•  FUNCTION:  based  on  the  plotting  range  of  x,  it  samples  the  function  in 
EQ  and  determines  the  minimum  and  maximum  values  of  y. 

•  CONIC:  sets  the  y-axis  scale  equal  to  the  x-axis  scale 

•  POLAR:  based  on  the  values  of  the  independent  variable  (typically  6),  it 
samples  the  function  in  EQ  and  determines  minimum  and  maximum  values 
of  both  x  and  y. 

•  PARAMETRIC:  produces  a  similar  result  as  POLAR  based  on  the  values  of 
the  parameter  defining  the  equations  for  x  and  y. 

•  TRUTH:  produces  no  action. 

•  BAR:  the  x-axis  range  is  set  from  0  \o  n+1  where  n  is  the  number  of 
elements  in  EDAT.  The  range  of  values  of  y  is  based  on  the  contents  of 
SDAT.  The  minimum  and  maximum  values  of  y  are  determined  so  that  the 
x-axis  is  always  included  in  the  graph. 

.     HISTOGRAM:  similar  to  BAR. 

•  SCATTER:  sets  x-  and  y-axis  range  based  on  the  contents  of  the 
independent  and  dependent  variables  from  SDAT. 

INFO  (12) 

The  function  INFO  is  interactive  only  (i.e.,  it  cannot  be  programmed).  When 
the  corresponding  soft  menu  key  is  pressed  it  provides  information  about  the 
current  plot  parameters. 
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mm 

The  variable  name  EQ  is  reserved  by  the  calculator  to  store  the  current 
equation  in  plots  or  solution  to  equations  (see  chapter  ...).  The  soft  menu  key 
labeled  EQ  in  this  menu  can  be  used  as  it  v^ould  be  if  you  have  your  variable 
menu  available,  e.g.,  if  you  press  [  EQ  ]  it  v/ill  list  the  current  contents  of  that 
variable. 


ERASE  (4) 

The  function  ERASE  erases  the  current  contents  of  the  graphics  v/indov/.  In 
programming,  it  can  be  used  to  ensure  that  the  graphics  v/indov/  is  cleared 
before  plotting  a  nev/  graph. 

DRAX  (5) 

The  function  DRAX  drav/s  the  axes  in  the  current  plot,  if  any  is  visible. 


DRAW  (6) 

The  function  DRAW  draws  the  plot  defined  in  PPAR. 
The  PTYPE  menu  under  PLOT  (1) 

The  PTYPE  menu  lists  the  name  of  all  tv/o-dimensional  plot  types  pre- 
programmed in  the  calculator.  The  menu  contains  the  following  menu  keys: 

I 

l: 


FUnCT|COniC|POLHR|PHRAH|TRUTH|DIFFE 


These  keys  correspond  to  the  plot  types  Function,  Conic,  Polar,  Parametric, 
Truth,  and  DiH  Eq,  presented  earlier.  Pressing  one  of  these  soft  menu  keys, 
while  typing  a  program,  will  place  the  corresponding  function  call  in  the 
program.    Press  [nxt)  (S^S  to  get  back  to  the  main  PLOT  menu. 

The  PPAR  menu  (2) 

The  PPAR  menu  lists  the  different  options  for  the  PPAR  variable  as  given  by  the 
following  soft  menu  key  labels.  Press  [nxt)  to  move  to  next  menus: 

nrrng:  -i.  i  573  nrrng:  -i.  i  373 
Res:  S.  ~\     Res:  S.  1 


Mil  1 1  |i  1 1  III  I  I  ii  I  I  ii  III    |i  I  II       I  nil  I  III  1 1  III  1 1  III  1 1 II  I  liii  I  I 
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Note:  the  SCALE  commands  shown  here  actually  represent  SCALE,  SCALEW, 
SCALEH,  in  that  order. 

The  following  diagram  illustrates  the  functions  available  in  the  PPAR  menu. 
The  letters  attached  to  each  function  in  the  diagram  are  used  for  reference 
purposes  in  the  description  of  the  functions  shown  below. 


a 

b 

c 

d 

e  -f 

INDEP 

DEPHD 

XRHG 

VRHG 

RES  RESET 

3 

h 

j 

k 

 ^CEHTR 

SCALE 

SCHLEW 

SCflLEH 

AXES 

HTICK 

m 

n 

1  ^PPflR 

INFO 

INFO  (n)  and  PPAR  (m) 
If  you  press  lEiuIilEI,  or  enter  C     J  i^ii 
of  the  current  PPAR  settings,  for  example: 


while  in  this  menu,  you  will  get  a  listing 


Indep:  X 

Depnd:  Y 

-6.5 

6.5 

Vrng: 

-3. 1 

3.2 

Res:  0. 

ppflRlinrol       1       1  IPLOT 

This  information  indicates  that  X  is  the  independent  variable  (Indep),  Y  is  the 
dependent  variable  (Depnd),  the  x-axis  range  goes  from  -6.5  to  6.5  (Xrng), 
the  y-axis  range  goes  from  -3.1  to  3.2  (Yrng).  The  last  piece  of  information 
in  the  screen,  the  value  of  Res  (resolution)  determines  the  interval  of  the 
independent  variable  used  for  generating  the  plot. 

The  soft  menu  key  labels  included  in  the  PPAR(2)  menu  represent  commands 
that  can  be  used  in  programs.  These  commands  include: 
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INDEP  (g) 

The  command  INDEP  specifies  the  independent  variable  and  its  plotting  range. 
These  specifications  are  stored  as  the  third  parameter  in  the  variable  PPAR. 
The  default  value  is  'X'.  The  values  that  can  be  assigned  to  the  independent 
variable  specification  are: 

•  A  variable  name,  e.g.,  'vel' 

•  A  variable  name  in  a  list,  e.g.,  {  Vel  } 

•  A  variable  name  and  a  range  in  a  list,  e.g.,  {  Vel  0  20  } 

•  A  range  v/ithout  a  variable  name,  e.g.,  {  0  20  } 

•  Two  values  representing  a  range,  e.g.,  0  20 

In  a  program,  any  of  these  specifications  will  be  followed  by  the  command 
INDEP. 

DEPND  (b) 

The  command  DEPND  specifies  the  name  of  the  dependent  variable.  For  the 
case  of  TRUTH  plots  it  also  specifies  the  plotting  range.  The  default  value  is  Y. 
The  type  of  specifications  for  the  DEPND  variable  are  the  same  as  those  for 
the  INDEP  variable. 

XRNG  (c)  and  YRNG  (d) 

The  command  XRNG  specifies  the  plotting  range  for  the  x-axis,  while  the 
command  YRNG  specifies  the  plotting  range  for  the  y-axis.  The  input  for  any 
of  these  commands  is  two  numbers  representing  the  minimum  and  maximum 
values  of  x  or  y.  The  values  of  the  x-  and  y-axis  ranges  are  stored  as  the 
ordered  pairs  (x^j„,  y^  J  and  [x^ax,  Ymax)  two  first  elements  of  the  variable 

PPAR.  Default  values  for  x^i„  and  x^^^  are  -6.5  and  6.5,  respectively.  Default 
values  for  x^i^  and  x^^x  are  -3.1  and  3.2,  respectively. 

RES  (e) 

The  RES  (RESolution)  command  specifies  the  interval  between  values  of  the 
independent  variable  when  producing  a  specific  plot.  The  resolution  can  be 
expressed  in  terms  of  user  units  as  a  real  number,  or  in  terms  of  pixels  as  a 
binary  integer  (numbers  starting  with  #,  e.g.,  #10).  The  resolution  is  stored  as 
the  fourth  item  in  the  PPAR  variable. 
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CENTR  (q) 

The  command  CENTR  takes  as  argument  an  ordered  pair  (x,y)  or  a  value  x, 
and  adjusts  the  first  two  elements  in  the  variable  PPAR,  i.e.,  (x^,„,  y^J  and 
(Xmaxj  Ymax)/  SO  thot  the  Center  of  the  plot  is  (x,y)  or  (x,0),  respectively. 

SCALE  (h) 

The  SCALE  command  determines  the  plotting  scale  represented  by  the  number 
of  user  units  per  tick  mark.  The  default  scale  is  1  user-unit  per  tick  mark. 
When  the  command  SCALE  is  used,  it  takes  as  arguments  two  numbers,  x^^^ig 
and  yscaie/  representing  the  new  horizontal  and  vertical  scales.  The  effect  of 
the  SCALE  command  is  to  adjust  the  parameters  (x^in,  y^i„)  and  (x„ax/  Ymax) 
PPAR  to  accommodate  the  desired  scale.  The  center  of  the  plot  is  preserved. 

SCALEW  (i) 

Given  a  factor  Xf^^^^,,  the  command  SCALEW  multiplies  the  horizontal  scale  by 
that  factor.  The  W  in  SCALEW  stands  for 'width.'  The  execution  of  SCALEW 
changes  the  values  of  x^j„  and  x^^^  in  PPAR. 

SCALEH  (i) 

Given  a  factor  yi^^^^r'      command  SCALEH  multiplies  the  vertical  scale  by  that 
factor.  The  H  in  SCALEH  stands  for  'height.'  The  execution  of  SCALEW 
changes  the  values  of  y^^^  and  y^^x PPAR. 


Note:  Changes  introduced  by  using  SCALE,  SCALEW,  or  SCALEH,  can  be 
used  to  zoom  in  or  zoom  out  in  a  plot. 


ATICK  (I) 

The  command  ATICK  (Axes  TICK  mark)  is  used  to  set  the  tick-mark  annotations 
for  the  axes.  The  input  value  for  the  ATICK  command  can  be  one  of  the 
following: 

•  A  real  value  x  :  sets  both  the  x-  and  y-axis  tick  annotations  to  x  units 

•  A  list  of  two  real  values  {  x  y  }:  sets  the  tick  annotations  in  the  x-  and  y- 
axes  to  X  and  y  units,  respectively. 

•  A  binary  integer  #n:  sets  both  the  x-  and  y-axis  tick  annotations  to  #n 
pixels 
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A  list  of  two  binary  integers  {#n  #m}:  sets  the  tick  annotations  in  the  x-  and  y- 
axes  to  #n  and  #m  pixels,  respectively. 


AXES  (k) 

The  input  value  for  the  axes  command  consists  of  either  an  ordered  pair  (x,y) 
or  a  list  {(x,y)  atick  "x-axis  label"  "y-axis  label"}.  The  parameter  afick  stands 
for  the  specification  of  the  tick  marking  annotations  as  described  above  for 
the  command  ATICK.  The  ordered  pair  represents  the  center  of  the  plot.  If 
only  an  ordered  pair  is  given  as  input  to  AXES,  only  the  axes  origin  is  altered. 
The  argument  to  the  command  AXES,  whether  an  ordered  pair  or  a  list  of 
values,  is  stored  as  the  fifth  parameter  in  PPAR. 

To  return  to  the  PLOT  menu,  press  iilElji. 

Press  [NxrJ  to  reach  the  second  menu  of  the  PLOT  menu  set. 

RESET  (f) 

This  button  will  reset  the  plot  parameters  to  default  values. 
The  3D  menu  within  PLOT  (7) 

The  3D  menu  contains  two  sub-menus,  PTYPE  and  VPAR,  and  one  variable, 
EQ.   We  are  familiar  already  with  the  meaning  of  EQ,  therefore,  we  will 
concentrate  on  the  contents  of  the  PTYPE  and  VPAR  menus.  The  diagram 
below  shows  the  branching  of  the  3D  menu. 
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XVOL 
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The  PTYPEmenu  within  3D  (IV) 

The  PTYPE  menu  under  3D  contains  the  following  functions: 


£LOPE|HIREF|Y£LIC|PCOnT|aRIDH|PHR£U 


These  functions  correspond  to  the  graphics  options  Slopefield,  Wireframe,  Y- 
Slice,  Ps-Contour,  Gridmap  and  Pr-Surface  presented  earlier  in  this  chapter. 
Pressing  one  of  these  soft  menu  keys,  while  typing  a  program,  will  place  the 
corresponding  function  coll  in  the  program.    Press  [w^lSaSS  to  get  back  to  the 
main  3D  menu. 

The  VPARmenu  within  3D  (V) 

The  variable  VPAR  stands  for  Volume  PARameters,  referring  to  a 

parallelepiped  in  space  within  which  the  three-dimensional  graph  of  interest  is 
constructed.   When  press  [VPAR]  in  the  3D  menu,  you  will  get  the  following 
functions.  Press  (.w-^J  to  move  to  the  next  menu: 


^iyol:          -1.  1. 
Vyol:          -1.  1. 
Zyol:          -1.  1. 
^irng:          -1.  1. 
Vrng:          -1.  1. 

"leye:  0. 
reye:  -3. 
Zeye:  0. 
^slspi  10. 
rstep:  S. 

KVOL 

vvoL  1  zvoL  iKKRncivvRnci  inro 

EVEPTI  mWA  1  nUMV  1  VPflR  IRESETI  IRFO 

Next,  we  describe  the  meaning  of  these  functions: 
INFO  (S)  and  VPAR  (W) 

When  you  press  liMiiii]  (S)  you  get  the  information  shown  in  the  left-hand  side 
screen  shot  above.  The  ranges  in  Xvo/,  Yvol,  and  Zvol  describe  the  extent  of 
the  parallelepiped  in  space  where  the  graph  will  be  generated.  Xrng  and 
Yrng  describe  the  range  of  values  of  x  and  y,  respectively,  as  independent 
variables  in  the  x-y  plane  that  will  be  used  to  generate  functions  of  the  form  z 
=  f(x,y). 

Press  jNXT]  and  iillay  (Y)  to  obtain  the  information  in  the  right-hand  side  screen 
shot  above.  These  are  the  value  of  the  location  of  the  viewpoint  for  the  three- 
dimensional  graph  (Xeye,  Yeye,  Zeye),  and  of  the  number  of  steps  in  x  and  y 
to  generate  a  grid  for  surface  plots. 


Page  22-9 


XVOL  (N),  YVOL  (O),  and  ZVOL  (P) 

These  functions  take  as  input  a  minimum  and  maximum  value  and  are  used  to 
specify  tfie  extent  of  tfie  parallelepiped  whiere  tfie  grapfi  will  be  generated 
(the  viewing  parallelepiped).    These  values  are  stored  in  the  variable  VPAR. 
The  default  values  for  the  ranges  XVOL,  YVOL,  and  ZVOL  are  -1  to  1 . 

XXRNG  (Q)  and  YYRNG  (R) 

These  functions  take  as  input  a  minimum  and  maximum  value  and  are  used  to 
specify  the  ranges  of  the  variables  x  and  y  to  generate  functions  z  =  f(x,y). 
The  default  value  of  the  ranges  XXRNG  and  YYRNG  will  be  the  same  as  those 
of  XVOL  and  YVOL. 


EYEPT  m 

The  function  EYEPT  takes  as  input  real  values  x,  y,  and  z  representing  the 
location  of  the  viewpoint  for  a  three-dimensional  graph.  The  viewpoint  is  a 
point  in  space  from  which  the  three-dimensional  graph  is  observed. 
Changing  the  viewpoint  will  produce  different  views  of  the  graph.    The  figure 
below  illustrates  the  idea  of  the  viewpoint  with  respect  to  the  actual  graphic 
space  and  its  projection  in  the  plane  of  the  screen. 

NUMX(U)  and  NUMY  (V) 

The  functions  NUMX  and  NUMY  are  used  to  specify  the  number  of  points  or 
steps  along  each  direction  to  be  used  in  the  generation  of  the  base  grid  from 
which  to  obtain  values  of  z  =  f(x,y). 


VPAR  (W) 

This  is  just  a  reference  to  the  variable  VPAR. 
RESET (X) 

Resets  parameters  in  screen  to  their  default  values. 
Press  ['wjES  to  return  to  the  3D  menu. 
Press  IGUEB  to  return  to  the  PLOT  menu. 
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The  STAT  menu  within  PLOT 

The  STAT  menu  provides  access  to  plots  related  to  statistical  analysis.  Within 
this  menu  we  find  the  following  menus: 


PTVPE  DflTfl  EPflR 


The  diagram  below  shows  the  branching  of  the  STAT  menu  within  PLOT.  The 
numbers  and  letters  accompanying  each  function  or  menu  are  used  for 
reference  in  the  descriptions  that  follow  the  figure. 


I 

PTYPE 

1 

1 1 

Dninl 


BAR  H  HISTOH  SCflTT 


I  2 PAR  I 

 I  J  ]       K  n 

XCOL  H  YCQlI-I  MODL  W  SPFIR  [TrESET  [jlNFol 


2+  Hl-HCLS  HSDflT 


LINFlf- 

juOGFI 

■IexpfiH  PHRFI  |- 

BESTF 
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ThePTYPE  menu  within  STAT  (I) 

The  PTYPE  menu  provides  the  following  functions: 


These  keys  correspond  to  the  plot  types  Bar  (A),  Histogram  (B),  and  Scatter(C), 
presented  earlier.  Pressing  one  of  these  soft  menu  keys,  while  typing  a 
program,  will  place  the  corresponding  function  call  in  the  program.  Press 
rauTlu  to  get  back  to  the  STAT  menu. 


T/ie  DATA  menu  wif/iin  STAT (II) 

The  DATA  menu  provides  the  following  functions: 


The  functions  listed  in  this  menu  are  used  to  manipulate  the  ZDAT  statistical 
matrix.  The  functions  Z+  (D)  and  Z-  (E),  add  or  remove  data  rows  from  the 
matrix  SDAT.   CLE  (F)  clears  the  SDAT  (G)  matrix,  and  the  soft  menu  key 
labeled  SDAT  is  just  used  as  a  reference  for  interactive  applications.  More 
details  on  the  use  of  these  functions  are  presented  in  a  later  chapter  on 
statistical  applications.    Press  iBiiljIiil  to  return  to  the  STAT  menu. 
The  SPAR  menu  within  STAT  (III) 
The  EPAR  menu  provides  the  following  functions: 


^icol:  1. 
Vcol:  2. 
Intercept:  0. 
Slope:  0. 
Model:  LIHFIT 


KCOL   VCOL   HODL   EPflR  RESET  IFIFO 


INFO  (Ml  and  ZPAR  (K) 

The  key  INFO  in  ZPAR  provides  the  information  shown  in  the  screen  shot 
above.  The  information  listed  in  the  screen  is  contained  in  the  variable  EPAR. 
The  values  shown  are  the  default  values  for  the  x-column,  y-column,  intercept 
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and  slope  of  a  data  fitting  model,  and  the  type  of  model  to  be  fit  to  the  data 
in  ZDAT. 


XCOL  (H) 

The  command  XCOL  is  used  to  indicate  which  of  the  columns  of  ZDAT,  if  more 
than  one,  will  be  the  x-  column  or  independent  variable  column. 

YCOL  (I) 

The  command  YCOL  is  used  to  indicate  which  of  the  columns  of  XDAT,  if  more 
than  one,  will  be  the  y-  column  or  dependent  variable  column. 

MODI  (J) 

The  command  MODL  refers  to  the  model  to  be  selected  to  fit  the  data  in 
SDAT,  if  a  data  fitting  is  implemented.  To  see  which  options  are  available, 
press  KEIiH.  You  will  get  the  following  menu: 


LinFI|LOGFI|EKPFI|PHRri|eE£TF|  EPHR 


These  functions  correspond  to  Linear  Fit,  Logarithmic  Fit,  Exponential  Fit, 
Power  Fit,  or  Best  Fit.  Data  fitting  is  described  in  more  detail  in  a  later 
chapter.    Press  sSiEE]  to  return  to  the  SPAR  menu. 

XPAR  (K) 

SPAR  is  just  a  reference  to  the  variable  SPAR  for  interactive  use. 
RESET  (U 

This  function  resets  the  contents  of  SPAR  to  its  default  values. 

Press  [nxtJ  li'liTiiil  to  return  to  the  STAT  menu.  Press  [PLOT]  to  return  to  the  main 
PLOT  menu. 

The  FLAG  menu  within  PLOT 

The  FLAG  menu  is  actually  interactive,  so  that  you  can  select  any  of  the 
following  options: 
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•  AXES:  when  selected,  axes  are  shown  if  visible  within  the  plot  area  or 
volume. 

•  CNCT:  when  selected  the  plot  is  produced  so  that  individual  points  are 

connected. 

•  SIMU:  when  selected,  and  if  more  than  one  graph  is  to  be  plotted  in  the 
same  set  of  axes,  plots  all  the  graphs  simultaneously. 

Press  iGBSa  to  return  to  the  PLOT  menu. 

Generating  plots  with  programs 

Depending  on  whether  we  are  dealing  with  a  two-dimensional  graph  defined 
by  a  function,  by  data  from  EDAT,  or  by  a  three-dimensional  function,  you 
need  to  set  up  the  variables  PPAR,  ZPAR,  and  /or  VPAR  before  generating  a 
plot  in  a  program.  The  commands  shown  in  the  previous  section  help  you  in 
setting  up  such  variables. 

Following  we  describe  the  general  format  for  the  variables  necessary  to 
produce  the  different  types  of  plots  available  in  the  calculator. 

Two-dimensional  graphics 

The  two-dimensional  graphics  generated  by  functions,  namely,  Function, 
Conic,  Paramefric,  Polar,  Trufh  and  Differenfial  Equation,  use  PPAR  with  the 
format: 

{   (Xmin,   Ymin)    (x^axf   Ymax)    indsp  TBS  3x6  3  ptyps  depend  } 

The  two-dimensional  graphics  generated  from  data  in  the  statistical  matrix 
SDAT,  namely,  Bar,  Histogram,  and  Scatter,  use  the  SPAR  variable  with  the 
following  format: 

{  x-column  y-column  slope  intercept  model  } 

while  at  the  same  time  using  PPAR  with  the  format  shown  above. 

The  meaning  of  the  different  parameters  in  PPAR  and  SPAR  were  presented  in 
the  previous  section. 
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Three-dimensional  graphics 

The  three-dimensional  graphics  available,  namely,  options  Slopefield, 
Wireframe,  Y-Slice,  Ps-Contour,  Gridmap  and  Pr-Surface,  use  the  VPAR 
variable  with  the  following  format: 

{^left^  ^rightf  Ynearr  Yfar/  ^low/  ^high/  ^min/  ^raaxf  Yminf  Ymax/  ^eye/ 
Yeyer     ^eye^     ^step^  Ystep} 

These  pairs  of  values  of  x,  y,  and  z,  represent  the  following: 

•  Dimensions  of  the  view  parallelepiped  (xieft,    x^ightf    Ynear^  Yfar, 

^low/  ^high) 

•  Range  of  X  and  y  independent  variables  (x^in,  x„,ax,   Ymin,  Ymax) 

•  Location  of  viewpoint  (Xeye  A     Yeye,  Zeye) 

•  Number  of  steps  in  the  x-  and  y-directions  (xgtep^  Ystep) 

Three-dimensional  graphics  also  require  the  PPAR  variable  with  the 
parameters  shown  above. 

The  variable  EQ 

All  plots,  except  those  based  on  ZDAT,  also  require  that  you  define  the 
function  or  functions  to  be  plotted  by  storing  the  expressions  or  references  to 
those  functions  in  the  variable  EQ. 


In  summary,  to  produce  a  plot  in  a  program  you  need  to  load  EQ,  if  required. 
Then  load  PPAR,  PPAR  and  SPAR,  or  PPAR  and  VPAR.  Finally,  use  the  name 
of  the  proper  plot  type:  FUNCTION,  CONIC,  POLAR,  PARAMETRIC,  TRUTH, 
DIFFEQ,  BAR,  HISTOGRAM,  SCATTER,  SLOPE,  WIREFRAME,  YSLICE, 
PCONTOUR,  GRIDMAP,  or  PARSURFACE,  to  produce  your  plot. 

Examples  of  interactive  plots  using  the  PLOT  menu 

To  better  understand  the  way  a  program  works  with  the  PLOT  commands  and 
variables,  try  the  following  examples  of  interactive  plots  using  the  PLOT  menu. 
Example  1  -  A  function  plot: 

[^Lm_(jr)  Get  PLOT  menu  (*) 

IIMlia  ininTIMI!  Select  FUNCTION  as  the  plot  type 

'^|r'  (w^CS  liial  Store  function  'Vr'  into  EQ 
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(ALPm)[^(s](E^  EEEEEI 
1  QTJCeD  10  r3.3.:  = 

1  L+/-J [ffcj  5  EIIH  [nxtJ 
{  (0,0)  {.4  .2}  "Rs"  "Sr"} 

in:!;";!:::!  (W)  mm 
[nxt]  ijjiiiil;] 

ii^a  (w]CHni] 

(Wi(W)EHi3EII@g 


Show  plot  parameters 

Define  'r'  as  the  indep.  variable 

Define 's'  as  the  dependent  variable 

Define  (-1 ,  1 0)  as  the  x-range 

Define  (-1,  5)  as  the  y-range 

Axes  definition  list 

Define  axes  center,  ticks,  labels 

Return  to  PLOT  menu 

Erase  picture,  draw  axes,  labels 

Draw  function  and  show  picture 

Removes  menu  labels 

Returns  to  normal  calculator  display 


(*)  PLOT  menu  available  through  user-defined  key  as  shown  earlier  in 
this  Chapter. 


Example  2  -  A  parametric  plot  (Use  RAD  as  angles): 

[^Lm_  (jT) 

MMUl^  LlJiJlJijJ 

{'SIN(t)+i*SIN(2*t)'}(^ 


{t  0  6.29}  Silia 

[alpha)  (y]  [enter]  HilMLl 


£.  £  L  JC^ri  2„  2  llilililll 
1 .  1  C^C^  1 ..  1  leiHiB 
{ (0,0)  {.4  .2}  "X(t)"  "Y(t)"} 


JUiJId  J  LlJlJli]  [NXT)  ulus 


Example  3  -  A  polar  plot: 


Get  PLOT  menu 

Select  PARAMETRIC  as  the  plot  type 
Define  complex  function  X+iY 
Store  complex  function  into  EQ 
Show  plot  parameters 
Define 't'  as  the  indep. variable 
Define  'Y'  as  the  dependent  variable 
Define  (-2.2,2.2)  as  the  x-range 
Define  (-1 . 1 , 1 . 1 )  as  the  y-range 
Axes  definition  list 
Define  axes  center,  ticks,  labels 
Return  to  PLOT  menu 
Erase  picture,  draw  axes,  labels 
Draw  function  and  show  picture 
Finish  plot 


Get  PLOT  menu 

Select  POLAR  as  the  plot  type 
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[WXTj  [NXTj  Mia  J  ViOiiiSaS 


I  ..^^  \  iriirai<?L~l 
(JWTJ  lUliHiJI 

B'S'nna's  r;irv:ni  i  \  

UUlJIdJ  UlJlJll]  L^J  ri.;l.:J.:d.a.:i 


'1+SIN(e)'(^  8138 


Store  complex  fund,  r  =  f{0)  into  EQ 

Show  plot  parameters 

Define  '9'  as  the  indep.  Variable 

Define  'Y'  as  the  dependent  variable 

Define  (-3,3)  as  the  x-range 

Define  (-0.5,2.5)  as  the  y-range 

Axes  definition  list 

Define  axes  center,  ticks,  labels 

Return  to  PLOT  menu 

Erase  picture,  draw  axes,  labels 

Draw  function  and  show  picture 

Remove  menu  labels 

Return  to  normal  calculator  display 


From  these  examples  we  see  a  pattern  for  the  interactive  generation  of  a  two- 
dimensional  graph  through  the  PLOT  menu: 

1  -  Select  PTYPE. 

2  -  Store  function  to  plot  in  variable  EQ  (using  the  proper  format,  e.g., 

'X(t)-MY(t)'  for  PARAMETRIC). 

3  -  Enter  name  (and  range,  if  necessary)  of  independent  and  dependent 
variables 

4  -  Enter  axes  specifications  as  a  list  {  center  atick  x-label  y-label  } 

5  -  Use  ERASE,  DRAX,  LABEL,  DRAW  to  produce  a  fully  labeled  graph  with 


This  same  approach  can  be  used  to  produce  plots  with  a  program,  except 
that  in  a  program  you  need  to  add  the  command  PICTURE  after  the  DRAW 
function  is  called  to  recall  the  graphics  screen  to  the  stack. 

Examples  of  program-generated  plots 

In  this  section  we  show  how  to  implement  with  programs  the  generation  of  the 
last  three  examples.  Activate  the  PLOT  menu  before  you  start  typing  the 
program  to  facilitate  entering  graphing  commands  (l  *-\        ZK)  ,  see  above). 

Example  1  -  A  function  plot.  Enter  the  following  program: 


axes 
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{PPAR  EQ}  PURGE 
Wr'  STEQ 
'r'  INDEP 
's'  DEPND 
FUNCTION 

{    (0.,0.)    { .4  .2} 

"Rs"   "Sr"    }  AXES 

-1.    5.  XRNG 

-1.    5.  YRNG 

ERASE  DRAW  DRAX  LABEL 

PICTURE  »■ 

Store  the  program  in  variable  PLOTl . 
press  BUSH!]. 

Example  2  -  A  parametric  plot.  Enter 

RAD   {PPAR  EQ}  PURGE 
'SIN (t) +i*SIN {2*t) '  STEQ 
{   t  0.    6.29}  INDEP 
'Y'  DEPND 

PARAMETRIC 

{    (0.,0.)    {.5    .5}  "X(t)" 

"Y(t)"    }  AXES 

-2.2  2.2  XRNG 

-1.1   1.1  YRNG 

ERASE  DRAW  DRAX  LABEL 

PICTURE 

Store  the  program  in  variable  PLOT2. 
press  iSME. 


Start  program 

Purge  current  PPAR  and  EQ 
Store  'Vr'  into  EQ 
Set  independent  variable  to  'r' 
Set  dependent  variable  to 's' 
Select  FUNCTION  as  the  plot  type 

Set  axes  information 
Set  X  range 
Set  y  range 

Erase  &  draw  plot,  axes,  and  labels 
Recall  graphics  screen  to  stack 

To  run  it,  press  I  w«  J ,  if  needed,  then 

the  following  program: 
Start  program 

Change  to  radians,  purge  vars. 
Store  'X(t)+iY(t)'  into  EQ 
Set  indep.  variable  to  'r',  with  range 
Set  dependent  variable  to  'Y' 
Select  PARAMETRIC  as  the  plot  type 

Set  axes  information 
Set  x  range 
Set  y  range 

Erase  &  draw  plot,  axes,  and  labels 
Recall  graphics  screen  to  stack 
End  program 
To  run  it,  press  L  w/;  J ,  if  needed,  then 
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Example  3  -  A  polar  plot.    Enter  the  following  program: 

Start  program 


RAD   {PPAR  EQ}  PURGE 
n  +  SIN(0)'  STEQ 
{  0  0.    6.29}  INDEP 

'Y'  DEPND 

POLAR 

{    (0.,0.)    {.5  .5} 

"x"  "y"}  AXES 

-3.      3.  XRNG 

- . 5     2.5  YRNG 

ERASE  DRAW  DRAX  LABEL 

PICTURE 


Cfiange  to  radians,  purge  vars. 

Store  'f(0)'  into  EQ 

Set   indep.   variable  to  '0',  with 

range 

Set  dependent  variable  to  'Y' 
Select  POLAR  as  the  plot  type 

Set  axes  information 
Set  X  range 
Set  y  range 

Erase  &  draw  plot,  axes,  and  labels 
Recall  graphics  screen  to  stack 
End  program 


Store  the  program  in  variable  PLOT3.  To  run  it,  press  [  j ,  if  needed,  then 
press  ISI^ili. 

These  exercises  illustrate  the  use  of  PLOT  commands  in  programs.  They  just 
scratch  the  surface  of  programming  applications  of  plots.  I  invite  the  reader  to 
try  their  own  exercises  on  programming  plots. 

Drawing  commands  for  use  in  programming 

You  can  draw  figures  in  the  graphics  window  directly  from  a  program  by 
using  commands  such  as  those  contained  in  the  PICT  menu,  accessible  by 
I  *n  J^gg_  (.wxTjICESIB.  The  functions  available  in  this  menu  are  the  following. 
Press  [NXTj  to  move  to  next  menu: 


PICT   PDIH   LinE  TLinE  EOX 


Obviously,  the  commands  LINE,  TLINE,  and  BOX,  perform  the  same 
operations  as  their  interactive  counterpart,  given  the  appropriate  input. 
These  and  the  other  functions  in  the  PICT  menu  refer  to  the  graphics  windows 
whose  X-  and  y-ronges  are  determined  in  the  variable  PPAR,  as  demonstrated 
above  for  different  graph  types.  The  functions  in  the  PICT  command  are 
described  next: 
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PICT 

This  soft  key  refers  to  a  variable  called  PICT  that  stores  the  current  contents  of 
the  graphics  window.  This  variable  name,  however,  cannot  be  placed  within 
quotes,  and  can  only  store  graphics  objects.  In  that  sense,  PICT  is  like  no 
other  calculator  variables. 


PDIM 

The  function  PDIM  takes  as  input  either  two  ordered  pairs  (x„in,ymin)  (Xmax/Ymax) 
or  two  binary  integers  #w  and  #h.  The  effect  of  PDIM  is  to  replace  the  current 
contents  of  PICT  with  an  empty  screen.  When  the  argument  is  (x^in,ymin) 
(Xmax/Ymax)/  these  volues  become  the  range  of  the  user-defined  coordinates  in 
PPAR.  When  the  argument  is  #w  and  #h,  the  ranges  of  the  user-defined 
coordinates  in  PPAR  remain  unchanged,  but  the  size  of  the  graph  changes  to 
#h  X  #v  pixels. 

PICT  and  the  graphics  screen 

PICT,  the  storage  area  for  the  current  graph,  can  be  thought  of  as  a  two 
dimensional  graph  with  a  minimum  size  of  131  pixels  wide  by  64  pixels  high. 
The  maximum  width  of  PICT  is  2048  pixels,  with  no  restriction  on  the 
maximum  height.  A  pixel  is  each  one  of  the  dots  in  the  calculator's  screen 
that  can  be  turned  on  (dark)  or  off  (clear)  to  produce  text  or  graphs.  The 
calculator  screen  has  1  31  pixels  by  64  pixels,  i.e.,  the  minimum  size  for  PICT. 
If  your  PICT  is  larger  than  the  screen,  then  the  PICT  graph  can  be  thought  of 
as  a  two  dimensional  domain  that  can  be  scrolled  through  the  calculator's 
screen,  as  illustrated  in  the  diagram  shown  next. 


LINE 

This  command  takes  as  input  two  ordered  pairs  (xi,yi)  (xj,  y-^,  or  two  pairs  of 
pixel  coordinates  {#n-^  #mi}  {#n2  #m2}.  It  draws  the  line  between  those 
coordinates. 


TUNE 

This  command  (Toggle  LINE)  takes  as  input  two  ordered  pairs  (xi,yi)  (xj,  y^^, 
or  two  pairs  of  pixel  coordinates  {#n^  #rni}  {#"2  ^nij}.  it  draws  the  line 
between  those  coordinates,  turning  off  pixels  that  are  on  in  the  line 
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BOX 

This  command  takes  as  input  two  ordered  pairs  (xi,yi)  (x2,  72),  or  two  pairs  of 
pixel  coordinates  {#ni  #mi}  {#n2  #m2}.  It  draws  the  box  whose  diagonals  are 
represented  by  the  two  pairs  of  coordinates  in  the  input. 


ARC 

This  command  is  used  to  draw  an  arc.  ARC  takes  as  input  the  following 
objects: 

•  Coordinates  of  the  center  of  the  arc  as  (x,y)  in  user  coordinates  or  {#n, 
#m}  in  pixels. 

•  Radius  of  arc  as  r  (user  coordinates)  or  #k  (pixels). 

•  Initial  angle  9i  and  final  angle  82. 
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PIX?,  PIXON,  and  PIXOFF 

These  functions  take  as  input  the  coordinates  of  point  in  user  coordinates, 
(x,y),  or  in  pixels  {#n,  #m}. 

•  PIX?  Checks  if  pixel  at  location  (x,y)  or  {#n,  #m}  is  on. 

•  PIXOFF  turns  off  pixel  at  location  (x,y)  or  {#n,  #m}. 

•  PIXON  turns  on  pixel  at  location  (x,y)  or  {#n,  #m}. 

PVIEW 

This  command  takes  as  input  the  coordinates  of  a  point  as  user  coordinates 
(x,y)  or  pixels  {#n,  #m},  and  places  the  contents  of  PICT  with  the  upper  left 
corner  at  the  location  of  the  point  specified.  You  can  also  use  on  empty  list 
as  argument,  in  which  case  the  picture  is  centered  in  the  screen.  PVIEW  does 
not  activate  the  graphics  cursor  or  the  picture  menu.  To  activate  any  of  those 
features  use  PICTURE. 

PX^C 

The  function  PX^C  converts  pixel  coordinates  {#n  #m}  to  user-unit  coordinates 

(x,y). 
C^PX 

The  function  C^PX  converts  user-unit  coordinates  (x,y)  to  pixel  coordinates 
{#n  #m}. 

Programming  examples  using  drawing  functions 

In  this  section  we  use  the  commands  described  above  to  produce  graphics 
with  programs.  Program  listing  are  provided  in  the  attached  diskette  or  CD 
ROM. 

Example  1  -  A  program  that  uses  drawing  commands 
The  following  program  produces  a  drawing  in  the  graphics  screen.  (This 
program  has  no  other  purpose  than  to  show  how  to  use  calculator  commands 
to  produce  drawings  in  the  display.) 
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DEG 

0.  100.  XRNG 
0.  50.  YRNG 
ERASE 

(5.,  2.5)  (95.,  47.5)  BOX 
(50.,  50.)  10.  0.  360.  ARC 
(50.,  50.)  12.-180.  180.  ARC 
1  8  FOR  j 


(50.,  50.)  DUP 
'12*COS(45*(j-l))'  ^NUM 
'12*SIN(45*(j-l))'  ^NUM 
R^  C 


+ 


Start  program 

Select  degrees  for  angular  measures 
Set  X  range 
Set  y  range 
Erase  picture 

Draw  box  from  (5,5)  to  (95,95) 
Draw  a  circle  center  (50,50),  r  =10. 
Draw  a  circle  center  (50,50),  r=  12. 
Draw  8  lines  within  the  circle 
Lines  are  centered  as  (50,50) 
Calculate  x,  other  end  at  50  +  x 
Calculates  y,  other  end  at  50  +  y 
Convert  x  y  to  (x,y),  complex  num. 
Add  (50,50)  to  (x,y) 


LINE 

NEXT 
{ }  PVIEW 


Draw  the  line 
End  of  FOR  loop 
Show  picture 


Example  2  -  A  program  to  plot  a  natural  river  cross-section 
This  application  may  be  useful  for  determining  area  and  wetted  perimeters  of 
natural  river  cross-sections.  Typically,  a  natural  river  cross  section  is  surveyed 
and  0  series  of  points,  representing  coordinates  x  and  y  with  respect  to  an 
arbitrary  set  of  coordinates  axes.  These  points  can  be  plotted  and  a  sketch  of 
the  cross  section  produced  for  a  given  water  surface  elevation.   The  figure 
below  illustrate  the  terms  presented  in  this  paragraph. 

The  program,  available  in  the  diskette  or  CD  ROM  that  comes  with  your 
calculator,  utilizes  four  sub-programs  FRAME,  DXBED,  GTIFS,  and  INTRP.  The 
main  program,  called  XSECT,  takes  as  input  a  matrix  of  values  of  x  and  y, 
and  the  elevation  of  the  water  surface  Y  (see  figure  above),  in  that  order.  The 
program  produces  a  graph  of  the  cross  section  indicating  the  input  data  with 
points  in  the  graph,  and  shows  the  free  surface  in  the  cross-section. 
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r 

(X3>y3)\ 

nXn-l-Yn-l) 

Y=W.S. 
elevation 

 X 

It  is  suggested  that  you  create  a  separate  sub-directory  to  store  the  programs. 
You  could  call  the  sub-directory  RIVER,  since  we  are  dealing  with  irregular 
open  channel  cross-sections,  typical  of  rivers. 

To  see  the  program  XSECT  in  action,  use  the  following  data  sets.  Enter  them 
as  matrices  of  two  columns,  the  first  column  being  x  and  the  second  one  y. 
Store  the  matrices  in  variables  with  names  such  as  XYDl  (X-Y  Data  set  1 )  and 
XYD2  (X-Y  Data  set  2).   To  run  the  program  place  one  of  the  data  sets  in  the 
stack,  e.g.,  (j««J  IlilMlii,  then  type  in  a  water  surface  elevation,  say  4.0,  and 
press  iiiSHIji.  The  calculator  will  show  an  sketch  of  the  cross-section  with  the 
corresponding  water  surface.   To  exit  the  graph  display,  press  Lowj . 

Try  the  following  examples: 

a^iiiiiiiJii  L^2_J  iKEiiiiiS.!! 
a'nT!'?!'ii!  ! — =j — 1  ErrpiTiipis"! 

i:L!L>i.l.4!ii!    L_^J  lL!l:H_:!!:!!3.i! 

a'nT!'?!'1!!  ! — 7 — \  BTPITIIPIS"! 

BiiiiiiiiJii   L_6_J  !L!:E3j3i3.!i 

Please  be  patient  when  running  program  XSECT.  Due  to  the  relatively  large 
number  of  graphics  functions  used,  not  counting  the  numerical  iterations,  it 
may  take  some  time  to  produce  the  graph  (about  1  minute). 
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Data  set  1  Data  set  2 


0.4  6.3 

1.0  4.9 

2.0  4.3 

3.4  3.0 

4.0  1.2 

5.8  2.0 

7.2  3.8 

7.8  5.3 

9.0  7.2 


X 

y 

0.7 

4.8 

1.0 

3.0 

1.5 

2.0 

2.2 

0.9 

3.5 

0.4 

4.5 

1.0 

5.0 

2.0 

6.0 

2.5 

7.1 

2.0 

8.0 

0.7 

9.0 

0.0 

10.0 

1.5 

10.5 

3.4 

11.0 

5.0 

Note:  The  program  FRAME,  as  originally  programmed  (see  diskette  or  CD 
ROM),  does  not  maintain  the  proper  scaling  of  the  graph.  If  you  want  to 
maintain  proper  scaling,  replace  FRAME  with  the  following  program: 

STOS  MINE  MAXZ  2  COL^  DUP  ^COL  DROP  -  AXL  ABS  AXL  2  0 
/  DUP  NEG  SWAP  2  COL^  +  ^ROW  DROP  SWAP  ^  yR  xR  131 
DUP  R^B  SWAP  yR  OBJ^  DROP  -  xR  OBJ^   DROP  -   /   *  FLOOR 
R^B  PDIM  yR  OBJ^  DROP  YRNG  xR  OBJ^   DROP  XRNG  ERASE  S-  S- 

This  program  keeps  the  width  of  the  PICT  variable  at  1  31  pixels  -  the 
minimum  pixel  size  for  the  horizontal  axis  -  and  adjusts  the  number  of  pixels 
in  the  vertical  axes  so  that  a  1 :1  scale  is  maintained  between  the  vertical  and 
horizontal  axes. 


Pixel  coordinates 

The  figure  below  shows  the  graphic  coordinates  for  the  typical  (minimum) 
screen  of  131x64  pixels.  Pixels  coordinates  are  measured  from  the  top  left 
corner  of  the  screen  {#  Oh  #  Oh},  which  corresponds  to  user-defined 
coordinates  (x^|„,  y^ax)-       The  maximum  coordinates  in  terms  of  pixels 
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correspond  to  the  lower  right  corner  of  the  screen  {#  82h  #3Fh},  which  in 
user-coordinates  is  the  point  (x^ax/  Ymin)-  The  coordinates  of  the  two  other 
corners  both  in  pixel  as  well  as  in  user-defined  coordinates  are  shown  in  the 
figure. 

{#    Oh    #0  h}  {#  82h    #  Ohj 

(  '^min  '   ymax  1  (   ^m!!.x  •   ^max  ' 

pr31X64  pixels] 

{#    Oh  #  3Fh}  ,#    82h  #3rh} 


Animating  graphics 

Herein  we  present  a  way  to  produce  animation  by  using  the  Y-Slice  plot  type. 
Suppose  that  you  want  to  animate  the  traveling  wave,  f(X,Y)  =  2.5  sin(X-Y). 
We  can  treat  the  X  as  time  in  the  animation  producing  plots  of  f(X,Y)  vs.  Y  for 
different  values  of  X.  To  produce  this  graph  use  the  following: 

•  (jT]i«»  simultaneously.   Select  Y-Slice  for  TYPE.   '2.5*SIN(X-Y)'  for 
EQ.  'X'forlNDEP.  Press  (W] iiillili. 

•  SDJM,,  simultaneously  (in  RPN  mode).  Use  the  following  values: 


^^^PLOT  HinDOH  -  Y-SLICE 

K-Ri3ht:5. 

l-Wmf-S. 

V-For:  5. 

Z-L*h:  -a. 5 

Z-Hish:  2.5 

ZnXif  HiniHUH  V, 

vol 

EDIT  1  1 

1  lERASE 

DRAH 

•  Press  iliiijiiis  IIMlIII.  Allow  some  time  for  the  calculator  to  generate  all 
the  needed  graphics.  When  ready,  it  will  show  a  traveling  sinusoidal 
wave  in  your  screen. 
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Animating  a  collection  of  graphics 

The  calculator  provides  the  function  ANIMATE  to  animate  a  number  of 
graphics  that  have  been  placed  in  the  stack.  You  can  generate  a  graph  in  the 
graphics  screen  by  using  the  commands  in  the  PLOT  and  PICT  menus.  To 
place  the  generated  graph  in  the  stack,  use  PICT  RCL.  When  you  have  n 
graphs  in  levels  n  through  1  of  the  stack,  you  can  simply  use  the  command  n 
ANIMATE  to  produce  an  animation  made  of  the  graphs  you  placed  in  the 
stack. 


Example  1  -  Animating  a  ripple  in  a  v/ater  surface 

As  an  example,  type  in  the  following  program  that  generates  1 1  graphics 
showing  a  circle  centered  in  the  middle  of  the  graphics  screen  and  whose 
radius  increase  by  a  constant  value  in  each  subsequent  graph. 


RAD 

131  R^B  64  R^B  PDIM 

0  lOOXRNG  0  100  YRNG 

1  1 1  FOR  j 
ERASE 

(50.,  50.)  '5*(i-l)'  ^NUM 
0  '2*k'  ^NUM  arc 
PICT  RCL 
NEXT 

1 1  ANIMATE 


Begin  program 

Set  angle  units  to  radians 
Set  PICT  to  131x64  pixels 
Set  X-  and  y-ranges  to  0-1 00 
Start  loop  with  j  =  1  ..  11 
Erase  current  PICT 
Centers  of  circles  (50,50) 
Draw  circle  center  r  =  5(j-l ) 
Place  current  PICT  on  stack 
End  FOR-NEXT  loop 
Animate 
End  program 


Store  this  program  in  a  variable  called  PANIM  (Plot  ANIMation).  To  run  the 
program  press  I  J  (if  needed)  lljlllliLyjJ.  It  takes  the  calculator  more  than  one 
minute  to  generate  the  graphs  and  get  the  animation  going.  Therefore,  be 
really  patient  here.  You  will  see  the  hourglass  symbol  up  in  the  screen  for 
what  seems  a  long  time  before  the  animation,  resembling  the  ripples 
produced  by  a  pebble  dropped  on  the  surface  of  a  body  of  quiescent  water, 
appears  in  the  screen.   To  stop  the  animation,  press  I  on  J . 
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The  1 1  graphics  generated  by  the  program  are  still  available  in  the  stack.  If 
you  want  to  re-start  the  animation,  simply  use:  1  1  ANIMATE.  (Function 
ANIMATE  is  available  by  using  C5D™5- (^""EI^IC^  EESH).  The 
animation  will  be  re-started.  Press  [jwj  to  stop  the  animation  once  more. 
Notice  that  the  number  1 1  will  still  be  listed  in  stack  level  1 .  Press  I  4  J  to 
drop  it  from  the  stack. 

Suppose  that  you  want  to  keep  the  figures  that  compose  this  animation  in  a 
variable.  You  can  create  a  list  of  these  figures,  let's  call  it  WLIST,  by  using: 


Press  1.  J  to  recover  your  list  of  variables.  The  variable  iiLslijlsyjl  should  now  be 
listed  in  your  soft-menu  keys.  To  re-animate  this  list  of  variables  you  could  use 
the  following  program: 


WLIST 
OBJ^ 
ANIMATE 


Start  program 

Place  list  WLIST  in  stack 

Decompose  list,  stack  level  1  =  11 

Start  animation 

End  program 


Save  this  program  in  a  variable  called  RANIM  (Re-ANIMate).   To  run  it,  press 


The  following  program  will  animate  the  graphics  in  WLIST  forward  and 
backwards: 


■^K  Start  program 

WLIST  DUP  Place  list  WLIST  in  stack,  make  extra  copy 

REVLIST  +  Reverse  order,  concatenate  2  lists 

OBJ^  Decompose  list  in  elements,  level  1  =  22 

ANIMATE  Start  animation 

'iy  End  program 

Save  this  program  in  a  variable  called  RANI2  (Re-ANImate  version  2).  To  run 

it,  press  yil±lilLiEd.  The  animation  now  simulates  a  ripple  in  the  surface  of 
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otherwise  quiescent  water  that  gets  reflected  from  the  walls  of  a  circular  tank 
back  towards  the  center.  Press  I  on  J  to  stop  the  animation. 


Example  2  -  Animating  the  plotting 
Suppose  that  you  want  to  animate 
1 ,  2,  3,  4,  in  the  same  set  of  axes 

RAD 

131  R^B  64  R^B  PDIM 
0  2  XRNG  0  20  YRNG 
0  4  FOR  j 

'X'^j'  STEQ 

ERASE 

DRAX  LABEL  DRAW 
PICT  RCL 
NEXT 

5  ANIMATE 


f  different  power  functions 
le  plotting  of  the  functions  f(x)  =  x",  n  =  0, 
You  could  use  the  following  program: 
Begin  program 
Set  angle  units  to  radians 
Set  PICT  screen  to  1  3 1  x64  pixels 
Set  X-  and  y-ranges 
Start  loop  with  j  =  0, 1,...,4 
Store  'X'^j'  in  variable  EQ 
Erase  current  PICT 
Draw  axes,  labels,  function 
Place  current  PICT  on  stack 
End  FOR-NEXT  loop 
Animate 


Store  this  program  in  a  variable  called  PWAN  (PoWer  function  ANimation). 
To  run  the  program  press  ChD  (if  needed)  !3™I1.  You  will  see  the  calculator 
drawing  each  individual  power  function  before  starting  the  animation  in 
which  the  five  functions  will  be  plotted  quickly  one  after  the  other.  To  stop 
the  animation,  press  [on  ]. 

More  information  on  the  ANIMATE  function 

The  ANIMATE  function  as  used  in  the  two  previous  examples  utilized  as  input 
the  graphics  to  be  animated  and  their  number.  You  can  use  additional 
information  to  produce  the  animation,  such  as  the  time  interval  between 
graphics  and  the  number  of  repetitions  of  the  graphics.  The  general  format  of 
the  ANIMATE  function  in  such  cases  is  the  following: 

n-graphs       {   n   { #X  #Y}   delay  rep   }  ANIMATE 
n  represents  the  number  of  graphics,  { #x  #Y}  stand  for  the  pixel  coordinates 
of  the  lower  right  corner  of  the  area  to  be  plotted  (see  figure  below),  delay  is 
the  number  of  seconds  allowed  between  consecutive  graphics  in  the 
animation,  and  rep  is  the  number  of  repetitions  of  the  animation. 
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Graphic  objects  (GROBs) 

The  word  GROB  stands  for  GRaphics  OBjects  and  is  used  in  the  calculator's 
environment  to  represent  a  pixel-by-pixel  description  of  an  image  that  has 
been  produced  in  the  calculator's  screen.  Therefore,  when  an  image  is 
converted  into  a  GROB,  it  becomes  a  sequence  of  binary  digits  (binary  dig/fe 
=  bits),  i.e.,  O's  and  I's.  To  illustrate  GROBs  and  conversion  of  images  to 
GROBS  consider  the  following  exercise. 

When  we  produce  a  graph  in  the  calculator,  the  graph  become  the  contents 
of  a  special  variable  called  PICT.  Thus,  to  see  the  last  contents  of  PICT,  you 
could  use:  PICT  RCL  (CS^^  C^ESii  Sill  C5D?a_  ). 

The  display  shows  in  stack  level  1  the  line  Graphic  131x64  (if  using  the 

standard  screen  size)  followed  by  a  sketch  of  the  top  part  of  the  graph.  For 

example,   

11 :  Graphiic  131  x  64 


-2.2 


SfflCKl  MEM  EfiCHf  TESTf TVPEf LIST 


If  you  press  then  the  graph  contained  in  level  1  is  shown  in  the 
calculator's  graphics  display.  Press  KHHS  to  return  to  normal  calculator 
display. 

The  graph  in  level  1  is  still  not  in  GROB  format,  although  it  is,  by  definition,  a 
graphics  object.  To  convert  a  graph  in  the  stack  into  a  GROB,  use:  (.  3  }[enter} 
I  *i  Jfflg_  [/vxrj||333all^iSiE[j.    Now  we  have  the  following  information  in  level  1 : 

3l 
Z: 

l:  Graphiic  1312S  x  S 
GROB  131  64  00000001 


-K]Roe|eLAnK|  not.  |axoR|  sue  |repl 


The  first  part  of  the  description  is  similar  to  what  we  had  originally,  namely. 
Graphic  131x64,  but  now  it  is  expressed  as  Graphic  13128  x  8. 
However,  the  graphic  display  is  now  replaced  by  a  sequence  of  zeroes  and 
ones  representing  the  pixels  of  the  original  graph.  Thus,  the  original  graph  as 
now  been  converted  to  its  equivalent  representation  in  bits. 
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You  can  also  convert  equations  into  GROBs.      For  example,  using  the 
equation  writer  type  in  the  equation  'X'^2+3'  into  stack  level  1,  and  then  press 
CTD(«^  C5D™^  (wr)S3333l^3IiEIij  .   You  will  now  have  in  level  1  the  GROB 
described  as: 

l:  Graphiic  2S  x  6 


-K]Roe|eLAnK|  not.  |axoR|  ^ue  |repl 


As  a  graphic  object  this  equation  can  now  be  placed  in  the  graphics  display. 
To  recover  the  graphics  display  press  CD  .  Then,  move  the  cursor  to  an  empty 
sector  in  the  graph,  and  press  SSSInxt }Inxt jfSSS.  The  equation  is 
placed  in  the  graph,  for  example: 


Thus,  GROBs  can  be  used  to  document  graphics  by  placing  equations,  or  text, 
in  the  graphics  display. 


The  GROB  menu 

The  GROB  menu,  accessible  through  (jn^l^G  (mxt)  i^Jiiiiii,  contains  the 
following  functions.  Press  Inxt)  to  move  to  the  next  menu: 


-K]Roe|eLAnK|  not.  \  Qy.ot.  \  ^ue  |repl 


-H.CD   LCD-f  SIZE  AniHA 


^GROB 

of  these  functions  we  have  already  used  SUB,  REPL,  (from  the  graphics  EDIT 
menu),  ANIMATE  [ANIMA],  and  ^GROB.  ([  PRG  ]  is  simply  a  way  to 
return  to  the  programming  menu.)  While  using  ^GROB  in  the  two  previous 
examples  you  may  have  noticed  that  I  used  a  3  while  converting  the  graph 
into  a  GROB,  while  I  used  a  1  when  I  converted  the  equation  into  a  GROB. 
This  parameter  of  the  function  ^GROB  indicates  the  size  of  the  object  that  is 
being  converted  into  a  GROB  as  0  or  1  -  for  a  small  object,  2  -  medium,  and 
3  -  large.   The  other  functions  in  the  GROB  menu  are  described  following. 
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BLANK 

The  function  BLANK,  with  arguments  #n  and  #m,  creates  a  blank  graphics 
object  of  width  and  height  specified  by  the  values  #n  and  #m,  respectively. 
This  is  similar  to  the  function  PDIM  in  the  GRAPH  menu. 

GOR 

The  function  GOR  (Graphics  OR)  takes  as  input  grob2  (a  target  GROB),  a  set 

of  coordinates,  and  grob,,  and  produces  the  superposition  of  grob,  onto 
grob2  (or  PICT)  starting  at  the  specified  coordinates.  The  coordinates  can  be 
specified  as  user-defined  coordinates  (x,y),  or  pixels  {#n  #m}.  GOR  uses  the 
OR  function  to  determine  the  status  of  each  pixel  (i.e.,  on  or  off)  in  the 
overlapping  region  between  grab,  and  grob2. 

GXOR 

The  function  GXOR  (Graphics  XOR)  performs  the  same  operation  as  GOR,  but 
using  XOR  to  determine  the  final  status  of  pixels  in  the  overlapping  area 
between  graphic  objects  grob^  and  grob2. 


Note:  In  both  GOR  and  GXOR,  when  grob2  is  replaced  by  PICT,  these 
functions  produce  no  output.  To  see  the  output  you  need  to  recall  PICT  to  the 
stack  by  using  either  PICT  RCL  or  PICTURE. 


^LCD 

Takes  a  specified  GROB  and  displays  it  in  the  calculator's  display  starting  at 
the  upper  left  corner. 

LCD^ 

Copies  the  contents  of  the  stack  and  menu  display  into  a  131  x  64  pixels 
GROB. 

SIZE 

The  function  SIZE,  when  applied  to  a  GROB,  shows  the  GROB's  size  in  the 
form  of  two  numbers.  The  first  number,  shown  in  stack  level  2,  represents  the 
width  of  the  graphics  object,  and  the  second  one,  in  stack  level  1,  shows  its 
height. 


Page  22-32 


An  example  of  a  program  using  GROB 

The  following  program  produces  the  graph  of  the  sine  function  including  a 
frame  -  drawn  with  the  function  BOX  -  and  a  GROB  to  label  the  graph. 
Here  is  the  listing  of  the  program: 


RAD 

131  R^B  64  R^B  PDIM 

-6.28  6.28  XRNG  -2.  2.  YRNG 

FUNCTION 

'SIN(X)'  STEQ 

ERASE  DRAX  LABEL  DRAW 

(-6.28,-2.)  (6.28,2.)  BOX 

PICT  RCL 

"SINE  FUNCTION" 

1  ^GROB 

(-6.,  1 .5)  SWAP 

GOR 

PICT  STO 

{ }  PVIEW 


Begin  program 

Set  angle  units  to  radians 

Set  PICT  screen  to  1 31  x64  pixels 

Set  X-  and  y-ranges 

Select  FUNCTION  type  for  graphs 

Store  the  function  sine  into  EQ 

Clear,  draw  axes,  labels,  graph 

Draw  a  frame  around  the  graph 

Place  contents  of  PICT  on  stack 

Place  graph  label  string  in  stack 

Convert  string  into  a  small  GROB 

Coordinates  to  place  label  GROB 

Combine  PICT  with  the  label  GROB 

Save  combined  GROB  into  PICT 

Bring  PICT  to  the  stack 

End  program 


Save  the  program  under  the  name  GRPR  (GROB  PRogram).  Press  ESSS  to  run 
the  program.  The  output  will  look  like  this: 


V 

-a. 

A  program  with  plotting  and  drawing  functions 

In  this  section  we  develop  a  program  to  produce,  draw  and  label  Mohr's 
circle  for  a  given  condition  of  two-dimensional  stress.  The  left-hand  side 
figure  below  shows  the  given  state  of  stress  in  two-dimensions,  with  and 
CTyy  being  normal  stresses,  and  x^y  =  x^^  being  shear  stresses.  The  right-hand 
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side  figure  shows  the  state  of  stresses  when  the  element  is  rotated  by  an  angle 
(|).    In  this  case,  the  normal  stresses  are  a'^x  and  a' while  the  shear  stresses 


The  relationship  between  the  original  state  of  stresses  (a^x,  cr^y,  Xxy,  Xyx)  and  the 
state  of  stress  when  the  axes  are  rotated  counterclockwise  by  f  (a'xx,  o'yy,  x'xy, 
I'yx),  can  be  represented  graphically  by  the  construct  shown  in  the  figure 
below. 

To  construct  Mohr's  circle  we  use  a  Cartesian  coordinate  system  with  the  x- 
axis  corresponding  to  the  normal  stresses  (a),  and  the  y-axis  corresponding  to 
the  shear  stresses  (t).  Locate  the  points  A(CTxx,Txy)  and  B  (Oyy,  Xxy),  and  draw 
the  segment  AB.  The  point  C  where  the  segment  AB  crosses  the  a„  axis  will 
be  the  center  of  the  circle.  Notice  that  the  coordinates  of  point  C  are  (y2-(ayy 
+  (Txy),  0).  When  constructing  the  circle  by  hand,  you  can  use  a  compass  to 
trace  the  circle  since  you  know  the  location  of  the  center  C  and  of  two  points, 
A  and  B. 

Let  the  segment  AC  represent  the  x-axis  in  the  original  state  of  stress.  If  you 
want  to  determine  the  state  of  stress  for  a  set  of  axes  x'-y',  rotated 
counterclockwise  by  an  angle  ^  with  respect  to  the  original  set  of  axes  x-y, 
draw  segment  A'B',  centered  at  C  and  rotated  clockwise  by  and  angle  2(/> 
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with  respect  to  segment  AB.  The  coordinates  of  point  A'  will  give  the  values 
(a'xx,x'xy),  while  those  of  B'  will  give  the  values  {a'yy,x'^^). 


F' 


The  stress  condition  for  which  the  shear  stress,  x'^y,  is  zero,  indicated  by 
segment  D'E',  produces  the  so-called  principal  stresses,  a''^,,  (at  point  D')  and 
a''yy  (at  point  E').  To  obtain  the  principal  stresses  you  need  to  rotate  the 
coordinate  system  x'-y'  by  an  angle  counterclockwise,  with  respect  to  the 
system  x-y.  In  Mohr's  circle,  the  angle  between  segments  AC  and  D'C 
measures  2(zi„. 

The  stress  condition  for  which  the  shear  stress,  x'^y,  is  a  maximum,  is  given  by 
segment  F'G'.  Under  such  conditions  both  normal  stresses,  =  a'yy  ,  are 
equal.  The  angle  corresponding  to  this  rotation  is  The  angle  between 
segment  AC  and  segment  F'C  in  the  figure  represents  2^^. 
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Modular  programming 

To  develop  the  program  that  will  plot  Mohr's  circle  given  a  state  of  stress,  we 
will  use  modular  programming.  Basically,  this  approach  consists  in 
decomposing  the  program  into  a  number  of  sub-programs  that  are  created  as 
separate  variables  in  the  calculator.  These  sub-programs  are  then  linked  by  a 
main  program,  that  we  will  call  MOHRCIRCL.  We  will  first  create  a  sub- 
directory called  MOHRC  within  the  HOME  directory,  and  move  into  that 
directory  to  type  the  programs. 

The  next  step  is  to  create  the  main  program  and  sub-programs  within  the  sub- 
directory. 

The  main  program  MOHRCIRCL  uses  the  following  sub-programs: 

•  INDAT:  Requests  input  of  ox,  ay,  xxy  from  user,  produces  a  list  aL  = 
{ctx,  tjy,  xxy}  as  output. 

•  CC&r:     Uses  aL  as  input,  produces  ctc  =  V'2(CTX-l-oy),  r  =  radius  of 
Mohr's  circle,  ^n  =  angle  for  principal  stresses,  as  output. 

•  DAXES:  Uses  ac  and  r  as  input,  determines  axes  ranges  and  draws 
axes  for  the  Mohr's  circle  construct 

•  PCIRC:  Uses  ac,  r,  and  (pn  as  input,  draw's  Mohr's  circle  by 
producing  a  PARAMETRIC  plot 

•  DDIAM:  Uses  ctL  as  input,  draws  the  segment  AB  (see  Mohr's  circle 
figure  above),  joining  the  input  data  points  in  the  Mohr's  circle 

•  aLBL:  Uses  aL  as  input,  places  labels  to  identify  points  A  and  B  with 
labels  "ax"  and  "ay". 

•  aAXS:  Places  the  labels  "a"  and  "t"  in  the  x-  and  y-axes,  respectively. 

•  PTTL:  Places  the  title  "Mohr's  circle"  in  the  figure. 


Running  the  program 

If  you  typed  the  programs  in  the  order  shown  above,  you  will  have  in  your 
sub-directory  MOHRC  the  following  variables:  PTTL,  aAXS,  PLPNT,  aLBL, 
PPTS,  DDIAM.     Pressing  (W)  you  find  also:  PCIRC,  DAXES,  ATN2,  CC&r, 
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INDAT,  MOHRC.  Before  re-ordering  the  variables,  run  the  program  once  by 
pressing  the  soft-key  labeled  IIIy!IIIil!!l.  Use  the  following: 

Launches  the  main  program  MOHRCIRCL 

dJCU^  Enter  ax  =  25 

CZDCS^  Enter  ay  =  75 

I  5  }[  0  J(hv7h]  Enter  rxy  =  50,  and  finish  data  entry. 


At  this  point  the  program  MOHRCIRCL  starts  calling  the  sub-programs  to 
produce  the  figure.  Be  patient.  The  resulting  Mohr's  circle  will  look  as  in  the 
picture  to  the  left. 


r 

Hiiii^Hribi  1 

Because  this  view  of  PICT  is  invoked  through  the  function  PVIEW,  we  cannot 
get  any  other  information  out  of  the  plot  besides  the  figure  itself.  To  obtain 
additional  information  out  of  the  Mohr's  circle,  end  the  program  by  pressing 
[ON ).  Then,  press  CT)  to  recover  the  contents  of  PICT  in  the  graphics 
environment.  The  Mohr's  circle  now  looks  like  the  picture  to  the  right  (see 
above). 


Press  the  soft-menu  keys  Ilijl!fl!i]!i3  and  i(!Sil3])ll.  At  the  bottom  of  the  screen  you  will 

find  the  value  of  ^corresponding  to  the  point  A{ax,  xxy),  i.e.,  (z*  =  0, 

{2.50E1,    5.00E1) . 

Press  the  right-arrow  key  ((T) )  to  increment  the  value  of  ^  and  see  the 
corresponding  value  of  x'^y).  For  example,  for  ^  =  45°,  we  have  the 
values  (a'^,  x'^^)  =  (1.00E2,  2.50E1)  =  (100,  25).  The  value  of  will  be 
found  at  an  angle  90°  ahead,  i.e.,  where  =  45  -i-  90  =  135°.  Press  the 
CD  key  until  reaching  that  value  of  ^,  we  find  (a'^,  x',y)  =  (-1  .OOE-1 0,-2.5El ) 
=  (0,  25). 
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To  find  the  principal  normal  values  press  (3J  until  the  cursor  returns  to  the 
intersection  of  the  circle  with  the  positive  section  of  the  a-axis.  The  values 
found  at  that  point  are  ^  =  59°,  and  (a',„  x'^^)  =  (1 .06E2,-1 .40E0)  =  (106,  - 
1 .40).  Now,  we  expected  the  value  of  x'^y  =  0  at  the  location  of  the  principal 
axes.  What  happens  is  that,  because  we  have  limited  the  resolution  on  the 
independent  variable  to  be  A^=  1°,  we  miss  the  actual  point  where  the  shear 
stresses  become  zero.  If  you  press  C3D  once  more,  you  find  values  of  are  (z> 
=  58°,  and  (a',„  x%)  =  (1 .06E2,5.51  E-1)  =  (106,  0.551).  What  this 
information  tell  us  is  that  somewhere  between  ^  =  58°  and  ^  =  59°,  the  shear 
stress,  x'xy,  becomes  zero. 

To  find  the  actual  value  of  ^n,  press  LonJ  .  Then  type  the  list  corresponding  to 
the  values  {ctx  ay  xxy},  for  this  case,  it  will  be  {  25    75    50  }  [enter] 

Then,  press  IS.  The  last  result  in  the  output,  58.2825255885°,  is  the 
actual  value  of 

A  program  to  calculate  principal  stresses 

The  procedure  followed  above  to  calculate  can  be  programmed  as 
follows: 


Program  PRNST: 

IN  DAT 
CC&r 

'>"  ^TAG 
3  ROLLD 
R^C  DUP 

C^R  +  "aPx"  ^TAG 
SWAP  C^R  -  "aPy"  ^TAG 

To  run  the  program  use: 


Start  program  PRNST  (PRiNcipal  STresses) 
Enter  data  as  in  program  MOHRCIRC 
Calculate  ac,  r,  and  fn,  as  in  MOHRCIRC 
Tag  angle  for  principal  stresses 
Move  tagged  angle  to  level  3 
Convert  ctc  and  r  to  (ac,  r),  duplicate 
Calculate  principal  stress  aPx,  tag  it 
Swap,calculate  stress  aPy,  tag  it. 
End  program  PRNST 

Start  program  PRNST 
Enter  ax  =  25 

Enter  ay  =  75 

Enter  xxy  =  50,  and  finish  data  entry. 
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The  result  is: 


4: 

3:  E!n:5S.2S25255SS5 

2:  (tPx:  105.90169943S 

l:  (TPy:t-5. 9016994375) 


HOHRClPRn^Tl   EC   |  PPHR  |  PTTL  | 


Ordering  the  variables  in  the  sub-directory 

Running  the  program  MOHRCIRCL  for  the  first  time  produced  a  couple  of  new 
variables,  PPAR  and  EQ.  These  ore  the  Plot  PARometer  and  EQuation 
variables  necessary  to  plot  the  circle.  It  is  suggest  that  we  re-order  the 
variables  in  the  sub-directory,  so  that  the  programs  EIIlEii  and  laflilsliji  are  the 
two  first  variables  in  the  soft-menu  key  labels.  This  can  be  accomplished  by 
creating  the  list  {  MOHRCIRCL  PRNST  }  using:  CW][^(^  ||TE|TE|3|  mm(cNm) 
And  then,  ordering  the  list  by  using:  SD™^ 

After  this  call  to  the  function  ORDER  is  performed,  press  (j««J .  You  will  now 
see  that  we  have  the  programs  MOHRCIRCL  and  PRNST  being  the  first  two 
variables  in  the  menu,  as  we  expected. 

A  second  example  of  Mohr's  circle  calculations 

Determine  the  principal  stresses  for  the  stress  state  defined  by  a^^  =  1  2.5  kPa, 
CTyy  =  -6.25  kPa,  and  x^y  =  -  5.0  kPa.  Draw  Mohr's  circle,  and  determine 
from  the  figure  the  values  of  a'^x,  cf'yy,  and  x'^y  if  the  angle  ^  =  35°. 

To  determine  the  principal  stresses  use  the  program  luullMil,  as  follows: 


C^ICEEBEil  Start  program  PRNST 

□DCTJCZDCTD^  Enter  ax  =12.5 

CTDCZDQDCSS^  Enter  ay  = -6.25 

5(.  +/-  J {cnter]  Enter  xxy  =  -5,  and  finish  data  entry. 
The  result  is: 

4l 

3:        Esn:  165.963756532 

2:  (jPx:  13.75 

l:  (jPy:(-7.5) 


HOHRClPRn^Tl   EC   |  PPHR  |  PTTL  | 


To  draw  Mohr's  circle,  use  the  program  IHuUHul,  as  follows: 
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[  VM<  JIEEIIIil^l  Start  program  PRNST 

□DCX)GDCID^  Enter  CTX=  12.5 

CTJCZJCTDCIDC^^  Enter  oy  = -6.25 

5(.  +/-  J {fNTER]  Enter  xxy  =  -5,  and  finish  data  entry. 

The  result  is: 


r 

,  ,  , 

To  find  the  values  of  the  stresses  corresponding  to  a  rotation  of  35°  in  the 
angle  of  the  stressed  particle,  we  use: 

(■    JcD  Clear  screen,  show  PICT  in  graphics  screen 

SUSTISl  S(!33")ll.  To  move  cursor  over  the  circle  showing  ^  and  (x,y) 

Next,  press  CD  until  you  read  ^  =  35.  The  corresponding  coordinates  are 
(1.63E0,  -1.05E1),  i.e.,  at   ^=35°,  a'^=  1.63  kPa,  and  a'^^  = -lO.SkPa. 

An  input  form  for  the  MohKs  circle  program 

For  a  fancier  way  to  input  data,  we  can  replace  sub-program  INDAT,  with  the 
following  program  that  activates  an  input  form: 

■^K  "MOHR'S  CIRCLE"   {    {   "ctx  : "  "Normal  stress  in  x"  0  } 

{   "ay:"  "Normal  stress  in  y"  0   }    {   "xxy:"  "Shear  stress" 

0}}        {}{111}{111}      INFORM  DROP  S- 

With  this  program  substitution,  running  II!lI!lI![IE!I  will  produce  an  input  form  as 

shown  next: 


CIRCLE  ^^^^ 

^1250.  1 

3600. 

Txy  -750. 

Fi^fHol  ftr<ff  in 

EDIT  1         1         1         ICHnCLI  OK 

Page  22-40 


Press  Sllii  to  continue  program  execution.  The  result  is  the  following  figure: 


r 

0 

Since  program  INDAT  is  used  also  for  program  iLiiiiiiMii  (PRiNcipal  STresses), 
running  that  particular  program  will  now  use  an  input  form,  for  example, 


CIRCLE  ^^^^ 

^123.  1 

TJty  56. 

Fi^fHOl  ftr<ff  in 

EDIT  1         1         1         ICHnCLI  OK 

The  result,  after  pressing  SSulIli,  is  the  following: 


7: 

6: 

5: 

4: 

3: 

Esn:  69.  949546227 

Z: 

(tPx:  276.  433196439 

l: 

trPy:  102.561303561 

inDflT|MOHRC|PRnST|   E4   |  PPflR  |  PTTL 
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Chapter  23 
Character  strings 


character  strings  are  calculator  objects  enclosed  between  double  quotes. 
They  are  treated  as  text  by  the  calculator.  For  example,  the  string  "SINE 
FUNCTION",  can  be  transformed  into  a  GROB  (Graphics  Object),  to  label  a 
graph,  or  can  be  used  as  output  in  a  program.  Sets  of  characters  typed  by 
the  user  as  input  to  a  program  are  treated  as  strings.  Also,  many  objects  in 
program  output  are  also  strings. 

String-related  functions  in  the  TYPE  sub-menu 

The  TYPE  sub-menu  is  accessible  through  the  PRG  (programming)  menu,  i.e., 
L  *i  JfflG    .  The  functions  provided  in  the  TYPE  sub-menu  are  also  shown  below. 


PROG  HEnU 


l.STRCK.. 
2.HEH0RY.. 
?.RRHnCH.. 
HJEST^ 

fi.LIST.. 


TYRE  HEnU 

^.C-tfi  II 

g.R-< 

10.CHR 

ll.DTHG 

11. [ 

1       1       1  IcflncL 

OK 

TYRE  HERU 

3.-H.IST 
H.-tSTR 
5 .  -fTflG 
fi.-KiniT 

1         1  1 

jCHRCL 

OK 

TYRE  HERU 

10.  CHR 

11.  DTHG 
la.E4-^ 
13. TYRE 
IH.VTYRE 

15.RR0GRAH..  1 

1       1       1  icflncL 

OK 

Among  the  functions  in  the  TYPE  menu  that  are  useful  for  manipulating  strings 
we  have: 

OBJ^:   Converts  string  to  the  object  it  represents 
^STR:    Converts  an  object  to  its  string  representation 
^TAG:   Tags  a  quantity 

DTAG:    Removes  the  tag  from  a  tagged  quantity  (de-tags) 
CHR:      Creates  a  one-character  string  corresponding  to  the  number  used  as 
argument 

NUM:     Returns  the  code  for  first  character  in  a  string 
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Examples  of  application  of  tfiese  functions  to  strings  are  sfiown  next: 


:0BJ-*("25.3") 

25.3 

:RHS(1>2 

 50.6 

OEJ-f|-tflRRV|-H.IST|  -tSTR 

-HflG  l-HiniT 

:CHR(65) 

"R" 

:CHR(210) 

"6" 

aEaiJMinii;ii 


CHR  IDTHGI  ECh 


■*TRG(5.  l+3.2/'RES") 

RES:S.3j 

■>TRG('X+1'/'EQ2") 

EQ2:(X+U 


ORJ-f  -tflRRV M-IST  tSTR   -HflG  HiniT 


:-*STR(25.2) 

"25.2" 

:->STR(12.6) 

"72" 

ORJ-f|-tflRRV|-H.IST|  -tSTR 

-HflG  l-HiniT 

:HUM("?") 

63. 

:HUM("i") 

123. 

BesixHiniiiinim 

DTflGI  E4-f 

:DTRG(Qm:X-6) 

X-6 

:DTRG(H:2) 

 2 

BesixHiniiiinim 

DTflGI  E4-f 

String  concatenation 

Strings  can  be  concatenated  (joined  together)  by  using  tfie  plus  sign  +,  for 
example: 


:"My  dog  "+"ate  it" 

'^Mlj  dQ9  ate  it" 
taMKgMinii;im!iaiaiMB«^ 

Concatenating  strings  is  a  practical  way  to  create  output  in  programs.  For 

example,  concatenating  "YOU  ARE  "  AGE  +  "  YEAR  OLD"  creates  the  string 

"YOU  ARE  25  YEAR  OLD",  where  25  is  stored  in  the  variable  called  AGE. 


The  CHARS  menu 

The  CHARS  sub-menu  is  accessible  through  the  PRG  (programming)  menu,  i.e.. 


PROG  HERU 

?.flftOE.. 

g.RICT..  

S. CHARS.. 

10.  MODES.. 

11.  in.. 

12.  OUT..  1 

1    1  1 

ICARCL 

OK 

The  functions  provided  by  the  CHARS  sub-menu  are  the  following: 
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CHHR  HEnU 

H.SIZE 

s.nuH 

1       1       1  icflncL 

OK 

CHAR  HERU 

g.-tSTR 
3. HEAD 

10.  TAIL 

11.  ^RERL 

12.RR0GRAH..  1 

1       1       1  icflncL 

OH 

The  operation  of  NUM,  CHR,  OBJ^,  and  ^STR  was  presented  earlier  in  this 
Chapter.  We  have  also  seen  the  functions  SUB  and  REPL  in  relation  to 
graphics  earlier  in  this  chapter.  Functions  SUB,  REPL,  POS,  SIZE,  HEAD,  and 
TAIL  have  similar  effects  as  in  lists,  namely: 

SIZE:  number  of  a  sub-string  in  a  string  (including  spaces) 

POS:  position  of  first  occurrence  of  a  character  in  a  string 

HEAD:  extracts  first  character  in  a  string 

TAIL:  removes  first  character  in  a  string 

SUB:  extract  sub-string  given  starting  and  ending  position 

REPL:  replace  characters  in  a  string  v/ith  a  sub-string  starting  at  given  position 

SREPL:  replaces  a  sub-string  by  another  sub-string  in  a  string 

To  see  those  effects  on  action  try  the  follov/ing  exercises:  Store  the  string  "MY 
NAME  IS  CYRILLE"  into  variable  SI .  We'll  use  this  string  to  show  examples  of 
the  functions  in  the  CHARS  menu: 


"MY  HRME  IS  CYRILLE"I> 
"MY  HRME  IS  CYRILLE" 
SIZE(Sl) 

IS. 

posts  l/'H") 

4. 


£UR    REPL    F-O^  \         \  RUH 


4. 

:HERD(S1) 

"M" 

:TRIL(S1) 

"Y  HRME 

IS  CYRILLE" 

:SUB(S14yJ 

"MY  HRME" 

£Ue  1  REPL  1  fOS 

REPL(S1.12/'J0SE  ") 
"MY  HRME  IS  JOSE 
■  SREPLtSl  "MY"/'HIS") 
{"HIS  HRME  IS  CYRILLE'^ 


+^HIP  SHIP-H  H)EL   DEL-f  DEL  L  IRS  i 


The  characters  list 

The  entire  collection  of  characters  available  in  the  calculator  is  accessible 
through  the  keystroke  sequence  [  r»  J        When  you  highlight  any  character. 


Page  23-3 


say  they  line  feed  character  ,  you  will  see  at  the  left  side  of  the  bottom  of 
the  screen  the  keystroke  sequence  to  get  such  character  (r->.  for  this  case)  and 
the  numerical  code  corresponding  to  the  character  (1 0  in  this  case). 

Characters  that  are  not  defined  appear  as  a  dark  square  in  the  characters  list 
(■)  and  show  (None)  at  the  bottom  of  the  display,  even  though  a  numerical 
code  exists  for  all  of  them.  Numerical  characters  show  the  corresponding 
number  at  the  bottom  of  the  display. 

Letters  show  the  code  a  (i.e.,  (alpha})  followed  by  the  corresponding  letter,  for 
example,  when  you  highlight  M,  you  will  see  aM  displayed  at  the  lower  left 
side  of  the  screen,  indicating  the  use  of  [alph^(^  .  On  the  other  hand,  m  shows 
the  keystroke  combination  a<nM,  or  [_m.pha]1  <n  . 

Greek  characters,  such  as  ct,  will  show  the  code  ar-»S,  or  {ujm]l  r>  ](s]  .  Some 
characters,  like  p,  do  not  have  a  keystroke  sequence  associated  with  them. 
Therefore,  the  only  way  to  obtain  such  characters  is  through  the  character  list 
by  highlighting  the  desired  character  and  pressing  SaSaS  or  uiSSI. 

Use  QllEilto  copy  one  character  to  the  stack  and  return  immediately  to 
normal  calculator  display.  Use  lillsIllLill  to  copy  a  series  of  characters  to  the 
stack.  To  return  to  normal  calculator  display  use  I  on  J . 

See  Appendix  D  for  more  details  on  the  use  of  special  characters.  Also, 
Appendix  G  shows  shortcuts  for  producing  special  characters. 


Page  23-4 


Chapter  24 

Calculator  objects  and  flags 

Numbers,  lists,  vectors,  matrices,  algebraics,  etc.,  are  calculator  objects. 
They  are  classified  according  to  its  nature  into  30  different  types,  which  are 
described  below.  Flags  are  variables  that  can  be  used  to  control  the 
calculator  properties.  Flags  were  introduced  in  Chapter  2. 


Description  of  calculator  objects 

The  calculator  recognizes  the  following  object  types: 


Number 

Type 

Example 

0 

Real  Number 

1 

Complex  Number 

2 

String 

!"  !       J.  .L  '_'  4          '_"  r    J.  '_] 

3 

Real  Array 

[[1  £3  LB  4]:] 

4 

Complex  Array 

[[a  2>  O  4>] 

[.(.5  6>  (.7  8>:i 

5 

List 

:":": 

6 

Global  Name 

■.J 

7 

Loco!  Name 

8 

Program 

9 

Algebraic  object 

1  a--^£:-i-b-'-2 ' 

10 

Binary  Integer 

#  FlSFlE  h 

11 

Graphic  Object 

!*"■  -  ._  L-  J    _     H        H  A 

■'..21           ill-    1.D1  XO'-t 

12 

Tagged  Object 

!■■■:  "       .■!  "i  C" 
i".  =     "tZi  ..  -1 

13 

Unit  Object 

3_r.i-"-2/s 

14 

XLIB  Name 

15 

Directory 

15  ik  I!  LNL5 

16 

Library 

Library  1230". 

17 

Backup  Object 

!■■■;  !  .  .  .  —     Ivl    J  n,  T  |-| 

!:::>■::!!-!■:.  UK  l"l  1  1-^  1 1"^- 

18 

Built-in  Function 

19 

Built-in  Command 

i~>  1  r~  r  1  r-i 
i.-.L-Einr. 
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Number  Type 


Example 


21  Extended  Real  Number  Long  F^eal 

22  Extended  Complex  Number       Lony  Complti-x 

23  Linked  Array  Linked  Array 

24  Character  Object  Character 

25  Code  Object  Code 

26  Library  Data  Library  Data 

27  External  Object  Elxti-ernal 

28  Integer  3423142 

29  External  Object  External 

30  External  Object  fcixternal 


Function  TYPE 

This  function,  available  in  the  PRO/TYPE  ()  sub-menu,  or  through  the  command 
catalog,  is  used  to  determine  the  type  of  an  object.  The  function  argument  is 
the  object  of  interest.  The  function  returns  the  object  type  as  indicated  by  the 
numbers  specified  above. 


:TYPE([2  3]) 

23. 

:TYPE("Q") 

2. 

:TYPE((2.  ,3.)) 

1. 

:TYPE('o:+l=p') 

9. 

:TYPE(I1  21) 

29. 

:TYPEK3  2  1» 

5. 

Function  VTYPE 

This  function  operates  similar  to  function  TYPE,  but  it  applies  to  a  variable 
name,  returning  the  type  of  object  stored  in  the  variable. 
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Calculator  flags 

A  flag  is  a  variable  that  can  either  be  set  or  unset.  The  status  of  a  flag  affects 
the  behavior  of  the  calculator,  if  the  flag  is  a  system  flag,  or  of  a  program,  if  it 
is  a  user  flag.  They  are  described  in  more  detail  next. 


System  flags 

System  flags  can  be  accessed  by  using  [mode}  Press  the  down  arrow 

key  to  see  a  listing  of  all  the  system  flags  with  their  number  and  brief 
description.  The  first  two  screens  with  system  flags  are  shown  below: 


5SVSTEM  FLAGS 


01  Generol  f*lu-ti*nf 


01  C^riftont  ■*  jyMb 

03  Function  ■*  lynb 

/  IH  PayHint  at  b«3in 

IS  -^a  ■*  vsitif 

20  Und«rFI.OH  ■*  0 

ai  OuifFUH  *  ±SEHSS 


SVSTEM  FLAGS 

aa  InFiniti  ■*  «rr*r 

/  a?  'K+YKi'  *  'K+VKi' 

as  Stqutntial.  put 

25  DroH  IXSi  t04 

31  C*ninct  p^intf 

32  Solid  cuFJor 


CAACL  OK 


CAnCL  OK 


You  will  recognize  many  of  these  flags  because  they  are  set  or  unset  in  the 
MODES  menu  (e.g.,  flag  95  for  Algebraic  mode,  103  for  Complex  mode, 
etc.).  Throughout  this  user's  manual  we  have  emphasized  the  differences 
between  CHOOSE  boxes  and  SOFT  menus,  which  are  selected  by  setting  or 
un-setting  system  flag  1 17.  Another  example  of  system  flag  setting  is  that  of 
system  flags  60  and  61  that  relate  to  the  constant  library  (CONLIB,  see 
Chapter  3).   These  flags  operate  in  the  following  manner: 


•  user  flag  60:  clear  (default):SI  units,  set:  ENGL  units 

•  user  flag  61 :  clear  {default):use  units,  set:  value  only 


Functions  for  setting  and  changing  flags 

These  functions  can  be  used  to  set,  un-set,  or  check  on  the  status  of  user  flags 
or  system  flags.  When  used  with  these  functions  system  flags  are  referred  to 
with  negative  integer  numbers.  Thus,  system  flag  1 1  7  will  be  referred  to  as 
flag  -1 1 7.  On  the  other  hand,  user  flags  will  be  referred  to  as  positive  integer 
numbers  when  applying  these  functions.  It  is  important  to  understand  that  user 
flags  have  applications  only  in  programming  to  help  control  the  program  flow. 
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Functions  for  manipulating  calculator  flogs  ore  available  in  the 
PRG/MODES/FLAG  menu.  The  PRG  menu  is  activated  v/ith  C2D«-  •  The 
follov/ing  screens  (v/ith  system  flog  1 1 7  set  to  CHOOSE  boxes)  shov/  the 
sequence  of  screens  to  get  to  the  FLAG  menu: 


PROG  HEnU 

g.PICT.. 
3. CHARS.. 

10.  MODES.. 

11.  in.. 

12.  OUT.. 

13.  TIME..  1 

1    1  1 

ICAnCL 

OK 

MODES  MEnU 

1.  FORMAT..  1 

2.  AnCLE..  1 

3.  FLAG.. 

H.KEYS..  1 

s.MEnu..  1 

G.MISC.  D 

1      1      1  IcAnoT 

OK 

The  functions  contained  within  the  FLAG  menu  are  the  following: 


FLAG  MEnU 

l.SF  1 

2.CF 

3.FS? 

H.FC? 

5.FS?C 

e.FC?C  1 

1         1         1  ICAnCL 

OK 

FLAG  MEnU 

5.FS?C  1 

S.FC?C 

?.STOF 

S.RCLF 

S. RESET 

10.  MODES..  1 

1         1         1  ICAnCL 

OK 

The  operation  of  these  functions  is  as  follows: 

SF  Set  a  flag 

CF  Clear  a  flag 

FS?  Returns  1  if  flag  is  set,  0  if  not  set 

FC?  Returns  1  if  flag  is  clear  (not  set),  0  if  flag  is  set 

FS?C  Tests  flag  as  FS  does,  then  clears  it 

FC?C  Tests  flog  as  FC  does,  then  clears  it 

STOF  Stores  new  system  flog  settings 

RCLF  Recalls  existing  flag  settings 

RESET  Resets  current  field  values  (could  be  used  to  reset  a  flag) 


User  flags 

For  programming  purposes,  flags  1  through  256  are  available  to  the  user. 
They  have  no  meaning  to  the  calculator  operation. 
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Chapter  25 

Date  and  Time  Functions 

In  this  Chapter  we  demonstrate  some  of  the  functions  and  calculations  using 
times  and  dates. 


The  TIME  menu 

The  TIME  menu,  available  through  the  keystroke  sequence  (.  J  time  (the  9  key) 
provides  the  follov/ing  functions,  which  are  described  next: 


a. Sit  oiofH.. 

3.  Sit  tiHl,  iite.. 
H.T**lf.. 

Setting  an  alarm 

Option  2.  Set  alarm.,  provides  an  input  form  to  let  the  user  set  an  alarm.  The 


input  form  looks  like  in  the  following  figure: 


TiH«  : 
Dote : 


9  -28  :00 

4'-12'-03 
Hone 


The  Message:  input  field  allows  you  to  enter  a  character  string  identifying  the 
alarm.  The  Time:  field  lets  you  enter  the  time  for  activating  the  alarm.  The 
Date:  field  is  used  to  set  the  date  for  the  alarm  (or  for  the  first  time  of 
activation,  if  repetition  is  required).  For  example,  you  could  set  the  following 
alarm.  The  left-hand  side  figure  shows  the  alarm  with  no  repetition.  The  right- 
hand  figure  shows  the  options  for  repetition  after  pressing  IMlEEIh.  After 
pressing  ilSSli  the  alarm  will  be  set. 


isn  alhrh: 
M«jo3<:  "WRKE  UP" 

TiH<:  9^30:00  PM 

Dots:        4^2 '■03 
Enttr  jUfH  rtptj't  HuUiplt 


EDIT  CHOOS 


Hill 

1 

TiH« 

a 

Dote 

3 
H 

5 

1         1         1  jCflnCLl 

OK 
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Browsing  alarms 

Option  7.  Browse  alarms...  in  the  TIME  menu  lets  you  review  your  current 
alarms.  For  example,  after  entering  the  alarm  used  in  the  example  above,  this 
option  will  show  the  following  screen: 


EDIT    HEH  PURG 


This  screen  provides  four  soft  menu  key  labels: 

EDIT:    For  editing  the  selected  alarm,  providing  an  alarm  set  input  form 
NEW:    For  programming  a  new  alarm 
PURG:  For  deleting  an  alarm 
OK    :  Returns  to  normal  display 

Setting  time  and  date 

Option  3.  Set  time,  date...  provides  the  following  input  form  that  let's  the  user 
set  the  current  time  and  date.  Details  were  provided  in  Chapter  1 . 


TIME  Tools 

Option  4.  Tools...  provides  a  number  of  functions  useful  for  clock  operation, 
and  calculations  with  times  and  dates.  The  following  figure  shows  the 
functions  available  under  TIME  Tools: 


TINE  HEnU 

3. TIME 
H.-HIME 
5. TICKS 
e.ALRH.. 

TINE  HEnU 

^^^^^^^^^^^[ 

3.-4IHS 

10.  HHS-» 

11.  HHS+ 

12.  HHS-  [ 

TINE  HEnU 


S.tHMS 

10.  HHS-» 

11.  HHS+ 

12.  HHS- 

13.  TSTR 
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The  application  of  these  functions  is  demonstrated  below. 

DATE:   Places  current  date  in  the  stack 

^DATE:  Set  system  date  to  specified  value 

TIME:    Places  current  time  in  24-hr  HH.MMSS  format 

^TIME:  Set  system  time  to  specified  value  in  24-hr  HH.MM.SS  format 

TICKS:  Provides  system  time  as  binary  integer  in  units  of  clock  ticks  with  1 

tick  =1/8192  sec 
ALRM..:Sub-menu  with  alarm  manipulation  functions  (described  later) 
DATE-F:  Adds  or  subtract  a  number  of  days  to  a  date 
DDAYS(x,y):  Returns  number  of  days  between  dates  x  and  y 
^HMS:  Converts  time  from  decimal  to  HH.MMSS 
HMS^:  Converts  time  from  HH.MMSS  to  decimal 
HMS-h:  Add  two  times  in  HH.MMSS  format 
HMS-:  Subtract  two  times  in  HH.MMSS  format 
TSTR(time,  date):  converts  time,  date  to  string  format 
CLKADJ(x):  Adds  x  ticks  to  system  time  (1  tick  =  1/81 92  sec  ) 

Functions  ^DATE,  ^TIME,  CLKADJ  ore  used  to  adjust  date  and  time.  There 
are  no  examples  provided  here  for  these  functions. 

Here  are  examples  of  functions  DATE,  TIME,  and  TSTR: 


iDflTE 

:TIME 

6.092003 

17. 1514201293 

:TIME 

:TSTR(RHS(2),RHS(1)) 

17. 1514201293 

"MOH  06.^09/03  05:  15: 1„, 

DHTE  I-4ATEI  TIHE  hTIHE|TICK£|  ALRH  | 

■  T£TR|CLKAD|         |         |  | 

Calculations  with  dates 

For  calculations  with  dates,  use  functions  DATE-i-,  DDAYS.  Here  is  an 
example  of  application  of  these  functions,  together  with  an  example  of 
function  TICKS: 


:DflTE 

6.092003 

:  DflTE-KDflTE,5) 

: T I CKS 

6. 142003 

#  lD70E27722700ti 

DflTE+|DDflVS|  -iHMS  |  HMS-f|  HMS+  |  HMS- 

DATE  |-*flTE|  TIME  |-HIHE|TICKS|  flLRM 
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Calculating  with  times 

The  functions  ^HMS,  HMS^,  HMS+,  and  HMS-  are  used  to  manipulate 
values  in  the  HH.MMSS  format.  This  is  the  some  format  used  to  calculate  with 
angle  measures  in  degrees,  minutes,  and  seconds.  Thus,  these  operations  are 
useful  not  only  for  time  calculations,  but  also  for  angular  calculations. 
Examples  are  provided  next:  


:HMS-*(12.3) 

12.5 

:->HMS(12.3333) 

12. 1959SS 

:HMS+(12.  3355,25.  3142) 
33.0537 

:HMS-(120.  1642,66.2145) 
53.5457 

DflTE+IDDflVSI  iHMS  |  HMS-f|  HMS+  |  HMS- 

DflTE+IDDflVSI  -HIMS  |  HMS-f|  HMS+  |  HMS- 

Alarm  functions 

The  sub-menu  TIME/Too 


S.../ALRM...  provides  the  following  functions: 


HLHRM  MEnU 

l.flCH 

2.HCHHLL 

^.STOHLARM 

H.RCLALARM 

5.DELALARM 

e.FinDALARM 

1    1  1 

ICAACLl 

OH 

The  operation  of  these  functions  is  provided  next: 
ACK:        Acknowledges  past  due  alarm 
ACKALL:   Acknowledges  oil  post  due  alarms 
STOALARM(x):  Stores  alarm  (x)  into  system  alarm  list 
RCLALARM(x):  Recalls  specified  alarm  (x)  from  system  alarm  list 
DELALARM(x):  Deletes  alarm  x  from  system  alarm  list 
FINDAIARM(x):  Returns  first  alarm  due  after  specified  time 


The  argument  x  in  function  STOALARM  is  a  list  containing  a  date  reference 
(mm.ddyyy),  time  of  day  in  24  hr  format  (hh.mm),  a  string  containing  the  text 
of  the  alarm,  and  the  number  of  repetitions  of  the  alarm.  For  example, 
STORLRRM a  6. 1392:803,  18.  25,  "Test"  ,  8>  .  The  argument  x  in  all 
the  other  alarm  functions  is  a  positive  integer  number  indicating  the  number  of 
the  alarm  to  be  recalled,  deleted,  or  found. 


Since  the  handling  of  alarms  can  be  easily  done  with  the  TIME  menu  (see 
above),  the  alarm-related  functions  in  this  section  are  more  likely  to  be  used 
for  programming  purposes. 
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Chapter  26 
Managing  memory 

In  Chapter  2  of  the  User's  Guide  we  introduced  the  basic  concepts  and 
operations  for  creating  and  managing  variables  and  directories.  In  this 
Chapter  we  discuss  the  management  of  the  calculator's  memory  in  terms  of 
partition  of  memory  and  techniques  for  backing  up  data. 

Memory  Structure 

The  calculator  contains  a  total  of  80  KB  to  be  used  for  calculator  operation 

and  data  storage  (user's  memory).  To  see  the  way  in  which  the  user's  memory 
is  partitioned,  use  the  FILES  function  ([  <n  Jf"^  ).  A  possible  result  is  shown 
below: 

L:ERAH 
a: FLASH 


ICAnCLl  OK 


This  screen  indicates  the  existence  of  one  memory  port  (port  0)  which  includes 
the  HOME  directory  (See  Chapter  2  in  the  User's  Guide). 
Port  0  and  the  HOME  directory  share  the  same  area  of  memory,  so  that  the 
more  data  stored  in  the  HOME  directory,  for  example,  the  less  memory  is 
available  for  Port  0  storage.  As  mentioned  above,  the  total  size  of  memory 
for  the  Port  0/HOME  directory  memory  area  is  80  KB. 

Port  0  and  the  HOME  directory  constitute  the  calculator's  RAM  (Random 
Access  Memory).  The  RAM  requires  continuous  electric  power  supply  from 
the  calculator  batteries  to  operate.  To  avoid  loss  of  the  RAM  memory 
contents,  a  CR2032  backup  battery  is  included.  See  additional  details  at  the 
end  of  this  chapter. 
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The  HOME  directory 

When  using  the  calculator  you  may  be  creating  variables  to  store  intermediate 
and  final  results.  Some  calculator  operations  such  as  graphics  or  statistical 
operations  create  their  own  variables  for  storing  data.  These  variables  will 
be  contained  within  the  HOME  directory  or  one  of  its  directories.  Details  on 
the  manipulation  of  variables  and  directories  are  presented  in  Chapter  2  of 
the  User's  Guide. 


Port  memory 

Unlike  the  HOME  directory,  port  memory  cannot  be  sub-divided  into 
directories,  and  it  can  only  contain  backup  objects  or  library  objects.  These 
object  types  are  described  below. 


Checking  objects  in  memory 

To  see  the  objects  stored  in  memory  you  can  use  the  FILES  function  (  [jjJi%iL_ 
The  screen  shows  the  HOME  directory  with  at  least  four  directories,  namely, 
GRPHS,  MPFIT,  MATRX,  and  TRIANG. 


IRAN 
ERAH 
FLASH 


2?2KR 

 SISKR 

MPFIT 
HATRK 

TRIAna  

Additional  directories  can  be  viewed  by  moving  the  cursor  downwards  in  the 
directory  tree.  Or  you  can  move  the  cursor  upwards  to  select  a  memory  port. 
When  a  given  directory,  sub-directory  or  port  is  selected,  press  SSulSSS  to  see 
the  contents  of  the  selected  object. 

Another  way  to  access  port  memory  is  by  using  the  LIB  menu  (L  r»  J  , 

associated  with  the  I  2  J  key).  This  action  produces  the  following  screen: 


If  you  have  any  library  active  in  your  calculator  it  will  be  shown  in  this  screen. 
Pressing  the  port  0  soft  menu  keys  will  open  that  memory  port.  Additional 
information  on  libraries  is  presented  below. 
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Backup  objects 

Backup  objects  are  used  to  copy  data  from  your  home  directory  into  a 
memory  port.  The  purpose  of  backing  up  objects  in  memory  port  is  to 
preserve  the  contents  of  the  objects  for  future  usage.  Backup  objects  have  the 
follov/ing  characteristics: 

•  Backup  objects  can  only  exist  in  port  memory  (i.e.,  you  cannot  back 
up  an  object  in  the  HOME  directory,  although  you  can  make  as  many 
copies  of  it  as  you  v/ant) 

•  You  cannot  modify  the  contents  of  a  backup  object  (you  can,  however, 
copy  it  back  to  a  directory  in  the  HOME  directory,  modify  it  there, 
and  back  it  up  again  modified) 

•  You  can  store  either  a  single  object  or  an  entire  directory  as  a  single 
backup  object.  You  cannot,  hov/ever,  create  a  backup  object  out  of  a 
number  of  selected  objects  in  a  directory. 

When  you  create  a  backup  object  in  port  memory,  the  calculator  obtains  a 
cyclic  redundancy  check  (CRC)  or  checksum  value  based  on  the  binary  data 
contained  in  the  object.   This  value  is  stored  with  the  backup  object,  and  is 
used  by  the  calculator  to  monitor  the  integrity  of  the  backup  object.  When 
you  restore  a  backup  object  into  the  HOME  directory,  the  calculator  obtains 
again  the  CRC  value  and  compares  it  to  the  original  value.  If  a  discrepancy 
is  noticed,  the  calculator  warns  the  user  that  the  restored  data  may  be 
corrupted. 

Backing  up  objects  in  port  memory 

The  operation  of  backing  up  an  object  from  user  memory  into  one  of  the 
memory  ports  is  similar  to  the  operation  of  copying  a  variable  from  one  sub- 
directory to  another  (see  details  in  Chapter  2  of  the  User's  Guide).   You  can, 
for  example,  use  the  File  Manager  ((jn^ima  )  to  copy  and  delete  backup 
objects  as  you  would  do  with  normal  calculator  objects.  In  addition,  there  are 
specific  commands  for  manipulating  back  up  objects,  as  described  next. 

Backing  up  and  restoring  HOME 

You  can  back  up  the  contents  of  the  current  HOME  directory  in  a  single  back 
up  object.  This  object  will  contain  all  variables,  key  assignments,  and  alarms 
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currently  defined  in  the  HOME  directory.  You  can  also  restore  the  contents  of 
your  HOME  directory  from  a  back  up  object  previously  stored  in  port  memory. 
The  instructions  for  these  operations  follow. 

Backing  up  the  HOME  directory 

To  back  up  the  current  HOME  directory  using  algebraic  mode,  enter  the 
command: 

ARCHIVE{:Port_Number:  Backup_Name) 

Here,  the  only  possible  value  for  Port_Number  is  0,  and  Backup_Name  is  the 
name  of  the  backup  object  that  will  store  the  contents  of  HOME.  The  : 

container  is  entered  by  using  the  keystroke  sequence  (3DU  •  For  example, 

to  back  up  HOME  into  HOME1  in  Port  0,  use: 


RRCHIVEtl:  HOMED 

HOVRU 


lOPflR  CflSDI 


To  back  up  the  HOME  directory  in  RPN  mode,  use  the  command: 

:  Port_Number :  Backup_Name  {mm}  ARCHIVE 
Restoring  the  HOME  directory 

To  restore  the  home  directory  in  algebraic  mode  use  the  command: 

RESTORE(;  Port_Number  :  Backup_Name) 
For  example,  to  restore  the  HOME  directory  out  of  backup  object  HOME!, 


In  RPN  mode  use: 

:  Port_Number  :  Backup_Name  RESTORE 

Note:  When  you  restore  a  HOME  directory  backup  two  things  happen: 

•  The  backup  directory  overwrites  the  current  HOME  directory.  Thus,  any 
data  not  backed  up  in  the  current  HOME  directory  will  be  lost. 

•  The  calculator  restarts.  The  contents  of  history  or  stack  are  lost. 
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Storing,  deleting,  and  restoring  backup  objects 

To  create  a  backup  object  use  one  of  the  following  approaches: 

•  Use  the  File  Manager  ([ jn^l files  )  to  copy  the  object  to  port.    Using  this 
approach,  the  backup  object  will  have  the  same  name  as  the  original 
object. 

•  Use  the  STO  command  to  copy  the  object  to  a  port.  For  example,  in 
algebraic  mode,  to  back  up  variable  A  into  a  backup  object  named  AA 
in  port  0,  use  the  keystroke  sequence: 

ISGSiQror)  (2DU  CUCD(d^(3(^(3l^ 

•  Use  the  ARCHIVE  command  to  create  a  backup  of  the  HOME  directory 
(see  above). 

To  delete  a  backup  object  from  a  port: 

•  Use  the  File  Manager  ([ jn^l files  )  to  delete  the  object  as  you  would  a 
variable  in  the  HOME  directory  (see  Chapter  2  in  the  User's  Guide). 

•  Use  the  PURGE  command  as  follows: 

In  algebraic  mode,  use:  PURGE(:  Port_Number  :  Backup_Name) 
In  RPN  mode,  use:  :  Port_Number :  Backup_Name  PURGE 

To  restore  a  backup  object: 

•  Use  the  File  Manager  (I  <n  J^^^  )  to  copy  the  backup  object  from  Port 
memory  to  the  HOME  directory. 

•  When  a  backup  object  is  restored,  the  calculator  performs  an  integrity 
check  on  the  restored  object  by  calculating  its  CRC  value.  Any 
discrepancy  between  the  calculated  and  the  stored  CRC  values  result  in 
an  error  message  indicating  a  corrupted  data. 

Using  data  in  backup  objects 

Although  you  cannot  directly  modify  the  contents  of  backup  objects,  you  can 
use  those  contents  in  calculator  operations.  For  example,  you  can  run 
programs  stored  as  backup  objects  or  use  data  from  backup  objects  to  run 
programs.  To  run  backup-object  programs  or  use  data  from  backup  objects 
you  can  use  the  File  Manager  (C5D™^  )  to  copy  backup  object  contents  to 
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the  screen.  Alternatively,  you  can  use  function  EVAL  to  run  a  program  stored 
in  a  backup  object,  or  function  RCL  to  recover  data  from  a  backup  object  as 
follov/s: 

•  In  algebraic  mode: 

■  To  evaluate  a  back  up  object,  enter: 
EVAL(argument(s),  :  Port_Number  :  Backup_Name  ) 

■  To  recall  a  backup  object  to  the  command  line,  enter: 
RCL(:  Port_Number :  Backup_Name) 

•  In  RPN  mode: 

■  To  evaluate  a  back  up  object,  enter: 

Argument(s)         :  Port_Number  :  Backup_Name  EVAL 

■  To  recall  a  backup  object  to  the  command  line,  enter: 
:  Port_Number :  Backup_Name  (.f/vraj  RCL 

Using  libraries 

Libraries  are  user-created  binary-language  programs  that  can  be  loaded  into 
the  calculator  and  made  available  for  use  from  v^ithin  any  sub-directory  of  the 
HOME  directory.  Libraries  can  be  downloaded  into  the  calculator  as  a 
regular  variable,  and,  then,  installed  and  attached  to  the  HOME  directory. 

Installing  and  attaching  a  library 

To  install  a  library,  list  the  library  contents  in  the  stack  (use  C3  variable  soft- 
menu  key,  or  function  RCL)  and  store  it  into  port  0.  For  example,  to  install  a 
library  variable  into  a  port  use: 

•  In  algebraic  mode:     STO(Library_variable,  port_number) 

•  In  RPN  mode:  Library_variable  [inter)  port_number  [smj 

After  installing  the  library  contents  in  port  memory  you  need  to  attach  the 
library  to  the  HOME  directory.   This  can  be  accomplished  by  rebooting  the 
calculator  (turning  the  calculator  off  and  back  on),  or  by  pressing, 
simultaneously,  [jwJGD  •  At  this  point  the  library  should  be  available  for  use. 

To  see  the  library  activation  menu  use  the  LIB  menu  {(jfj  ).   The  library 

name  v/ill  be  listed  in  this  menu. 
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Library  numbers 

If  you  use  the  LIB  menu  (LiiJ  )  and  press  the  soft  menu  key  corresponding 

to  port  0,  you  will  see  library  numbers  listed  in  the  soft  menu  key  labels.  Each 
library  has  a  four-digit  number  associated  with  it.  These  numbers  are 
assigned  by  the  library  creator,  and  are  used  for  deleting  a  library. 

Deleting  a  library 

To  delete  a  library  from  a  port,  use: 

•  In  algebraic  mode:     PURGE(:port_number:  lib_number) 

•  In  RPN  mode:  :  port_number  :  lib_number  PURGE 

Where  lib_number  is  the  library  number  described  above. 
Creating  libraries 

A  library  can  be  written  in  Assembler  language,  in  System  RPL  language,  or 
by  using  a  matrix-creating  library  such  as  LBMKR.  The  latter  program  is 
available  online  (see  for  example,  http://www.hpcalc.org).  The  details  of 
programming  the  calculator  in  Assembler  language  or  in  System  RPL  language 
are  beyond  the  scope  of  this  document.  The  user  is  invited  to  find  additional 
information  on  the  subject  online. 

Backup  battery 

A  CR2032  back  up  battery  is  included  in  the  calculator  to  provide  power 
backup  to  volatile  memory  when  changing  the  main  batteries.  It  is 
recommended  that  you  replace  this  battery  every  5  years.  A  screen  message 
will  indicate  when  this  battery  needs  replacement.  The  diagram  below  shows 
the  location  of  the  backup  battery  in  the  top  compartment  at  the  back  of  the 
calculator. 
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Appendix  A 
Using  input  forms 

This  example  of  setting  time  and  date  illustrates  the  use  of  input  forms  in  the 
calculator.  Some  general  rules: 

•  Use  the  arrow  keys  (C3D  CD  ^^5?  )  to  move  from  one  field  to  the 
next  in  the  input  form. 

•  Use  any  the  .:.:.:H!il  soft  menu  key  to  see  the  options  available  for  any 
given  field  in  the  input  form. 

•  Use  the  arrow  keys  (C3D  CD )  to  select  the  preferred  option  for 
a  given  field,  and  press  the  I9SEII  (C^D )  soft  menu  key  to  make  the 
selection. 

•  In  some  instances,  a  check  mark  is  required  to  select  an  option  in  an 
input  form.  In  such  case  use  the  i^^HIIli  soft  menu  key  to  toggle  the 
check  mark  on  and  off. 

•  Press  the  f::.:".:'.: .:°  soft  menu  key  to  close  on  input  form  and  return  to  the 
stack  display.  You  can  also  press  the  I^nter]  key  or  the  I  on  J  key  to 
close  the  input  form. 

Example  -  Using  input  forms  in  the  NUM.SLV  menu 

Before  discussing  these  items  in  detail  we  will  present  some  of  the 
characteristics  of  the  input  forms  by  using  input  forms  from  the  financial 
calculation  application  in  the  numerical  solver.    Launch  the  numerical  solver 
by  using  Ij^]numslv  (associated  with  the  I  7  J  key).    This  produces  a  choose 
box  that  includes  the  following  options: 


diff  It.. 
3.S*lu<  poly.. 
H. Solus  lin  s])s.. 
5. Solus  financs.. 
S.HSLV 

1     1     1  1 

CflnCLl 

UK 

To  get  started  with  financial  calculations  use  the  down  arrow  key 

)  to  select  itenn  5.  Solve  finance.  Press  WSM,  to  launch  the 
application.  The 
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resulting  screen  is  an  input  form  with  input  fields  for  a  number  of  variables  (n, 
l%YR,  PV,  PMT,  FV). 


TIME  VALUE  OF  MOHEV 
PV:  0.00 

PMT:  0.  00  p/VR:  12 

FV:    0.00  End 

Enttr  n^.  ^F  pjjjHtn'tJ  SOLVE 


AMOR  SOLVE 


in  this  particular  case  we  can  give  values  to  all  but  one  of  the  variables,  say, 
n  =  1 0,  l%YR  =  8.5,  PV  =  1 0000,  FV  =  1 000,  and  solve  for  variable  PMT 
(the  meaning  of  these  variables  will  be  presented  later).  Try  the  following: 


1  0  B"^''J.'5" 

8.5SSIISI 

10000 


^1000 
The  resulting  screen  is: 


Enter  n  =  10 
Enter  l%YR  =  8.5 
Enter  PV  =  1  0000 
Enter  FV  =  1 000 
Select  and  solve  for  PMT 


TIME  VALUE  OF  MOREV^M 
R:       10  IKVR:  S.  5 

PV:  10000.00 

PMT:  HlKS»fta  P^YR:  12 

FV:  1000.00  End 
Entif  payHint  OHOunt  *r  SOLVE 


AMOR  SOLVE 


In  this  input  form  you  will  notice  the  following  soft  menu  key  labels: 


Press  to  edit  highlighted  field 
□Mij     Amortization  menu  ■  option  specific  to  this  application 
y^|yig23    Press  to  solve  for  highlighted  field 


Pressing  Inxt)  we  see  the  following  soft  menu  key  labels: 


T-i— — ±  rjrjrjrj  .  rjrj —  

PMT:  HlKS»fta  P^YR:  12 

FV:   1000.00  End 

Zntic  poaA<nt  OAOunt  *r  SOLVE 


RESET  CALC  TYPES 


Reset  fields  to  default  values 
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Press  to  access  the  stack  for  calculations 


gjilSi^ii    Press  to  determine  the  type  of  object  in  highlighted  field 
SnSS    Cancel  operation 
SESI!      Accept  entry 

If  you  press  ■i'.':'.'L"you  will  be  asked  to  select  between  the  two  options: 


TIHE  VHLUE  OF  HOHEY 
n:      10  I^VR:  S.  5 

fV 


PMT: 

FV:     njt)(j.  Ql  iC 

Zntic  poymnt  OHOunt  *r  SOLVE 


If  you  select  Reset  value  only  the  highlighted  value  will  be  reset  to  the  default 
value.  If,  instead,  you  select  Rest  all,  all  the  fields  will  be  reset  to  their  default 
values  (typically,  0).  At  this  point  you  can  accept  your  choice  (press  iilljlli),  or 
cancel  the  operation  (press  EallSa).  Press  EallSa  in  this  instance.   Press  EalS 
to  access  the  stack.  The  resulting  screen  is  the  following: 


TIHE  VHLUE  OF  HOHEY 
Entsr  pjaHtnt  jHoun't  SOLVE 


PMT:  (-1136. 22451577) 
-1136.22451577 


At  this  point,  you  have  access  to  the  stack,  and  the  value  last  highlighted  in 
the  input  form  is  provided  for  you.  Suppose  that  you  want  to  halve  this  value. 
The  following  screen  follows  in  ALG  mode  after  entering 

1 136.22/2: 


TIHE  VHLUE  OF  HOHEY 
Entsr  pjaHtnt  jHoun't  SOLVE 


-1136.22451577^ 
-1136.22 

2 

-563. 11 


cnncL  OK 
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(In  RPN  mode,  we  would  have  used  1 1  36.22  (wn?]  2  IjNmjl^ ). 

Press  iiylli  to  enter  this  new  value.  The  input  form  will  now  look  like  this: 


TIME  VALUE  OF  MOHEV^M 
n:      10  I^VR:  S.  5 

fv-  issss.ss 

FV:   1000.00  End 

Zntic  poaH<nt  OHOunt  *r  SOLVE 


RESET  CflLC  TYPES 


Press  EEuSlBi  to  see  the  type  of  data  in  the  PMT  field  (the  highlighted  field).  As  a 
result,  you  get  the  following  specification: 


TINE  VALUE  OF  HOREY 
R:       1  Q  TyVR:  H  5 

PMT: 
FV: 


Valid  ibjsit  t-fffi- 


En't<r  poaA<nt  OAOunt  *r  SOLVE 


This  indicates  that  the  value  in  the  PMT  field  must  be  a  real  number.  Press 
to  return  to  the  input  form,  and  press  L  to  recover  the  first  menu.  Next, 
press  the  (mh)  key  or  the  I  on  J  key  to  return  to  the  stack.  In  this  instance,  the 
following  values  will  be  shown: 


-1136.22451577 
. -1136.22 

2 


+^KIP|SKIP^  H)EL  I  DEL-f|DEL  L|  IRS  ■ 


The  top  result  is  the  value  that  was  solved  for  PMT  in  the  first  part  of  the 
exercise.  The  second  value  is  the  calculation  we  made  to  redefine  the  value 
of  PMT. 
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Appendix  B 

The  calculator's  keyboard 

The  figure  below  shows  a  diagram  of  the  calculator's  keyboard  with  the 
numbering  of  its  rows  and  columns. 


Column:   1       2       3       4       5  6 
▼        T        T        T        ▼  T 

Row 

1  ► 

2  ► 

3  ► 

4  ► 

5  ► 

6  ► 
/► 

8  ► 

9  ► 
10  ► 

▲  ▲AAA 

Column:    12         3        4  5 


The  figure  shows  1 0  rows  of  keys  combined  with  3,  5,  or  6  columns.    Row  1 
has  6  keys,  rows  2  and  3  have  3  keys  each,  and  rows  4  through  1 0  have  5 
keys  each.  There  are  4  arrow  keys  located  on  the  right-hand  side  of  the 


CMDUNDO  PRG  CHARS  MTRW  EQW  MTH  CAT    DEL  CLEAR 

evaln)  ( 

1/7     ASIN  2: 
SIN  s] 
<  < 


X  XJ 

USER  ENTRY  S.SLV  NUM.SLV  EXP8.LNTRIG  FINANCE  TIME  [  J 

[alpha]  [TJ  (^sJ  I  I  X 

CALC  ALG  MATRICES  STAT  CONVERT  UNrTS  ( )  — 


ARITH  CMPD<  DEE     LIB     #    BASE  {)«» 


CONT  OEE  oo 


ON       I  0 

CANCEL 


>  ANS-NUM 
ENTER 
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keyboard  in  the  space  occupied  by  rows  2  and  3.    Each  key  has  three,  four, 
or  five  functions.  The  main  key  functions  are  shown  in  the  figure  below.  To 
operate  this  main  key  functions  simply  press  the  corresponding  key.   We  will 
refer  to  the  keys  by  the  row  and  column  where  they  are  located  in  the  sketch 
above,  thus,  key  (10,l)\s  the  ON  key. 


CANCEL 


▲  A  ▲  ▲  ▲ 

Column:    12         3        4  5 


Main  key  functions  in  the  calculator's  keyboard 
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Main  key  functions 

Keys  PfT]  through  (jQ  keys  are  associated  with  the  soft  menu  options  that 
appear  at  the  bottom  of  the  calculator's  display.  Thus,  these  keys  will  activate 
a  variety  of  functions  that  change  according  to  the  active  menu. 

■  The  arrow  keys,       Vt^  CD  CD ,  are  used  to  move  one  character  at  a 
time  in  the  direction  of  the  key  pressed  (i.e.,  up,  down,  left,  or  right). 

■  The  APPS  function  activates  the  applications  menu. 

■  The  MODE  function  activates  the  calculator's  modes  menu. 

■  The  TOOL  function  activates  a  menu  of  tools  useful  for  handling  variables 
and  getting  help  on  the  calculator. 

■  The  VAR  function  shows  the  variables  stored  in  the  active  directory,  the 
STO  function  is  used  to  store  contents  in  variables. 

■  The  NXr  function  is  used  to  see  additional  soft  menu  options  or  variables 
in  a  directory. 

■  The  H/S7" function  allows  you  access  to  the  algebraic-mode  history,  i.e., 
the  collection  of  recent  command  entries  in  that  mode. 

■  The  EVAL  key  is  used  to  evaluate  algebraic  and  numeric  expressions,  the 
apostrophe  key  [  '  ]  is  used  to  enter  a  set  of  apostrophes  for  algebraic 
expressions. 

■  The  SYMB  activates  the  symbolic  operations  menu. 

■  The  delete  key  L_4J  is  used  to  delete  characters  in  a  line. 

■  The  y  key  calculates  the  x  power  of  /. 

■  TheV^  key  calculates  the  square  root  of  a  number. 

■  The  SIN,  COS,  and  TAN  keys  calculate  the  sine,  cosine,  and  tangent, 
respectively,  of  a  number. 

■  The  EEX  key  is  used  to  enter  power  of  tens  (e.g.,  5xJ0^,  is  entered  as 
mfffi^m,  which  is  shown  as  5E3). 

■  The  +/-  key  changes  the  sign  of  an  entry,  the  X  key  enters  the  character  X 
(upper  case). 

■  The  7/x  key  calculates  the  inverse  of  a  number,  the  keys  +,  -,     and  ^, 
are  used  for  the  fundamental  arithmetic  operations  (addition,  subtraction, 
multiplication,  and  division,  respectively). 

■  The  ALPHA  key  is  combined  with  other  keys  to  enter  alphabetic  characters. 
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■  The  left-shiff  key  [jT)  and  the  right-shift  key  LiU  are  combined  with  other 
keys  to  activate  menus,  enter  characters,  or  calculate  functions  as 
described  elsewhere. 

■  The  numerical  keys  (0  to  9)  are  used  to  enter  the  digits  of  the  decimal 
number  system. 

■  There  is  a  decimal  point  key  (.)  and  a  space  key  (SPQ. 

■  The  ENTER  key  is  used  to  enter  a  number,  expression,  or  function  in  the 
display  or  stack,  and 

■  The  ON  key  is  used  to  turn  the  calculator  on. 

Alternate  key  functions 

The  green  left-shift  key,  key  (8, 1),  the  red  right-shift  key,  key  (9, 1),  and  the 
blue  ALPHA  key,  key  (7, 1),  can  be  combined  with  some  of  the  other  keys  to 
activate  the  alternative  functions  shown  in  the  keyboard.    For  example,  the 
isTMBj  key,  key(4,4),  has  the  following  six  functions  associated  with  it: 

Main  function,  to  activate  the  SYMBolic  menu 
Left-shift  function,  to  activate  the  MTH  (Math)  menu 
Right-shift  function,  to  activate  the  CATalog  function 
ALPHA  function,  to  enter  the  upper-case  letter  P 
ALPHA-Left-Shift  function,  to  enter  the  lower-case  letter  p 
ALPHA-Right-Shift  function,  to  enter  the  symbol  P 

Of  the  six  functions  associated  with  the  key  only  the  first  four  are  shown  in  the 
keyboard  itself.  This  is  the  way  that  the  key  looks  in  the  keyboard: 

MTH  CAT 

f  ^ 


SYMB  P 


Notice  that  the  color  and  the  position  of  the  labels  in  the  key,  namely,  SYMB, 
MTIH,  CAT  and  P,  indicate  which  is  the  main  function  (SYMB),  and  which  of 


[sm) 

[alpha](p] 
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the  other  three  functions  is  associated  with  the  left-shift  [Jjj  (MTH),  right- 
shift  CZD  (CAT)  ,  and  (alpha]  (P)  keys. 

Diagrams  showing  the  function  or  character  resulting  from  combining  the 
calculator  keys  with  the  left-shift  [jT],  right-shift  [73,  ALPHA  fALPHA}^  ALPHA-left- 
shift  (^™](jT],  and  ALPHA-right-shift  (^^JLHJ,  are  presented  next.  In  these 
diagrams,  the  resulting  character  or  function  for  each  key  combination  is 
shown  in  white  background.  If  the  left-shift,  right-shift  or  ALPHA  keys  are 
activated  they  are  shown  in  a  shaded  background.  Keys  that  do  not  get 
activated  are  shown  in  black  background. 

Left-shift  functions 

The  following  sketch  shows  the  functions,  characters,  or  menus  associated  with 
the  different  calculator  keys  when  the  left-shift  key  [Jnj  is  activated. 

■  The  six  left-shift  functions  associated  with  the  ffT]  through  (jD  keys  are 
associated  with  the  setting  up  and  production  of  graphics  and  tables. 
When  using  these  functions  in  the  calculator's  Algebraic  mode  of 
operation,  press  the  left-shift  key  Ijjj  first,  and  then  any  of  the  keys  in 
Row  1 .  When  using  these  functions  in  the  calculator's  RPN mo6e,  you 
need  to  press  the  left-shift  key  CjnJ simultaneously  with  the  key  in  Row  1  of 
your  choice.  Function  Y=  is  used  to  enter  functions  of  the  form  y=f(x)  for 
plotting,  function  WIN  is  used  to  set  parameters  of  the  plot  window, 
function  GRAPH  is  used  to  produce  a  graph,  function  2D/3D  is  used  to 
select  the  type  of  graph  to  be  produced,  function  TBLSET  is  used  to  set 
parameters  for  a  table  of  values  of  a  function,  function  TABLE  is  used  to 
generate  a  table  of  values  of  a  function, 

■  Function  FILE  activates  the  file  browser  in  the  calculator's  memory. 

■  The  CUSTOM  function  activates  the  custom  menu  options,  the  /  key  is 
used  to  enter  the  unit  imaginary  number  /  into  the  stack  (i^  =  —1 ). 

■  The  UPDIR  function  moves  the  memory  location  one  level  up  in  the 
calculator's  file  tree. 

■  The  RCL  function  is  used  to  recall  values  of  variables. 

■  The  PREV  function  shows  the  previous  set  of  six  menu  options  associated 
with  the  soft  menu  keys. 
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■     The  CMD  function  shows  the  most  recent  commands,  the  PRG  function 
activates  the  programming  menus,  the  A/ir/?W function  activates  the 
Matrix  Writer, 
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Row 
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Column:    12         3        4  5 

Left-shift  C^iD  functions  of  the  calculator's  keyboard 


■  The  CMD  function  shows  the  most  recent  commands. 

■  The  PRG  function  activates  the  programming  menus. 

■  The  A/17RW  function  activates  the  Matrix  Writer. 

■  The  MTH  function  activates  a  menu  of  mathematical  function. 

■  The  DEL  key  is  used  to  delete  variables. 
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■  The  e"  key  calculates  the  exponential  function  of  x. 

■  The     key  calculates  the  square  of  x  (this  is  referred  to  as  the  SQ 
function). 

■  The  ASIN,  ACOS,  and  ATAN  functions  calculate  the  arcsine, 
arccosine,  and  arctangent  functions,  respectively. 

■  The  KT' function  calculates  the  anti-logarithm  of  x. 

■  The  keys     <,  and  >,  are  used  for  comparing  real  numbers. 

■  The  ABS  function  calculates  the  absolute  value  of  a  real  number,  or 
the  magnitude  of  o  complex  number  or  of  a  vector. 

■  The  USER  function  activates  the  user-defined  keyboard  menu. 

■  The  S.SiV function  activates  the  symbolic  solver  menu. 

■  The  EXP&LN  function  activates  the  menu  for  substituting  expressions  in 
terms  of  the  exponential  and  natural  logarithm  functions. 

■  The  F/NANCE  function  activates  a  menu  for  financial  calculations. 

■  The  CA/.C  function  activates  a  menu  of  calculus  functions. 

■  The  MATRICES  function  activates  a  menu  for  creating  and 
manipulation  of  matrices. 

■  The  CONVERT  function  activates  a  menu  for  conversion  of  units  and 
other  expressions. 

■  The  ARITH  function  activates  a  menu  of  arithmetic  functions. 

■  The  DEF  key  is  used  to  define  a  simple  function  as  a  variable  in  the 
calculator  menu. 

■  The  CONT  key  is  used  to  continue  a  calculator  operation. 

■  The  ANS  key  recalls  the  last  result  v/hen  the  calculator  is  in  Algebraic 
operation  mode. 

■  The  [],(),  and  {  }  keys  are  used  to  enter  brackets,  parentheses,  or 

braces. 

■  The  #  key  is  used  to  enter  numbers  in  other  than  the  active  number 
base. 

■  The  infinity  key  oo  is  used  to  enter  the  infinite  symbol  in  on  expression. 

■  The  pi  key  ;r  is  used  to  enter  the  value  or  symbol  for  ;r(the  ratio  of  the 
length  of  a  circumference  to  its  diameter). 

■  The  arrow  keys,  when  combined  with  the  left-shift  key,  move  the 
cursor  to  the  first  character  in  the  direction  of  the  key  pressed. 


Page  B-7 


Column:   1       2       3       4       5  6 
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Right-shift  (j^  functions  of  the  calculator's  keyboard 
Right-shift  functions 

The  sketch  above  shows  the  functions,  characters,  or  menus  associated  with 
the  different  calculator  keys  when  the  right-shift  key  CS  is  activated. 

■  The  functions  BEGIN,  END,  COPY,  CUT  an6  PASTE  are  used  for  editing 
purposes. 

■  The  UNDO  key  is  used  to  undo  the  last  calculator  operation. 

■  The  CHARS  function  activates  the  special  characters  menu. 

■  The  EQW  function  is  used  to  start  the  Equation  Writer. 
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■  The  CAT  function  is  used  to  activate  the  command  catalog. 

■  The  CLEAR  function  clears  the  screen. 

■  The  LN  function  calculates  the  natural  logarithm. 

■  The  ^fy  function  calculates  the  x-  th  root  of  y. 

■  The  S  function  is  used  to  enter  summations  (or  the  upper  case  Greek  letter 

sigma). 

■  The  d  function  is  used  to  calculate  derivatives. 

■  The  /  function  is  used  to  calculate  integrals. 

■  The  LOG  function  calculates  the  logarithm  of  base  1 0. 

■  The  ARG  function  calculates  the  argument  of  a  complex  number. 

■  The  f/S/T/?y  function  is  used  to  change  entry  mode  in  editing. 

■  The  NL/A/I. Si V  function  launches  the  NUMerical  SOLver  menu. 

■  The  TRIG  function  activates  the  trigonometric  substitution  menu. 

■  The  T/A/IE  function  activates  the  time  menu. 

■  The  ALG  function  activates  the  algebra  menu. 

■  The  STAT  function  activates  the  statistical  operations  menu. 

■  The  UNITS  function  activates  the  menu  for  units  of  measurement. 

■  The  CA/IPLY  function  activates  the  complex  number  functions  menu. 

■  The  LIB  function  activates  the  library  functions. 

■  The  BASE  function  activates  the  numeric  base  conversion  menu. 

■  The  OFF  key  turns  the  calculator  off,  the  -^NUM  key  produces  a  numeric 
(or  floating-point)  value  of  an  expression. 

■  The  "  "  key  enters  a  set  of  double-quotes  used  for  entering  text  strings. 

■  The  key  enters  an  underscore. 

■  The  «  »  key  enters  the  symbol  for  a  program. 

■  The  "*•  key  enters  an  arrow  representing  an  input  in  a  program. 

■  The      key  enters  a  return  character  in  programs  or  text  strings. 

■  The  comma  (,)  key  enters  a  comma. 

■  The  arrov/  keys,  when  combined  with  the  right-shift  key,  move  the  cursor 
to  the  farthest  character  in  the  direction  of  the  key  pressed. 

ALPHA  characters 

The  following  sketch  shows  the  characters  associated  with  the  different 
calculator  keys  when  the  ALPHA  [mma]  is  activated.  Notice  that  the  (^™] 
function  is  used  mainly  to  enter  the  upper-case  letters  of  the  English  alphabet 
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(A  through  Z).  The  numbers,  mathematical  symbols  (-,  +),  decimal  point  (.), 
and  the  space  (SPQ  are  the  same  as  the  main  functions  of  these  keys.  The 
(mpma}  function  produces  an  asterisk  (*)  when  combined  with  the  times  key,  i.e., 

(ALPHA}(j><_j  . 


A         A  ▲         A  ▲ 

Column:    12         3        4  5 


Alpha  f^LPHA}  functions  of  the  calculator's  keyboard 
Alpha-left-shift  characters 

The  following  sketch  shows  the  characters  associated  with  the  different 
calculator  keys  when  the  ALPHA        is  combined  with  the  left-shift  key  (Jn 


Page  B-10 


Notice  that  the  {alphai[jjJ  combination  is  used  mainly  to  enter  the  lower-case 
letters  of  the  English  alphabet  (A  through  Z).  The  numbers,  mathematical 
symbols  (-,     x),  decimal  point  (.),  and  the  space  (SPQ  are  the  same  as  the 
main  functions  of  these  keys.  The  ENTER  and  CONT  keys  also  work  as  their 
main  function  even  when  the  (^™j[JnJ  combination  is  used. 
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Alpha  [alpha}[^tJ  functions  of  the  calculator's  keyboard 


Page  B-1  1 


Alpha-right-shift  characters 

The  following  sketch  shows  the  characters  associated  with  the  different 
calculator  keys  when  the  ALPHA        is  combined  with  the  right-shift  key  (j^ 
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Alpha  [ALmA)[j^  functions  of  the  calculator's  keyboard 

Notice  that  the  Ialpha]{j^  combination  is  used  mainly  to  enter  a  number  of 
special  characters  from  into  the  calculator  stack.  The  CLEAR,  OFF,  , 
comma  (,),  key  enters  and  OFF  keys  also  work  as  their  main  function  even 
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when  the  t^™)LiU  combination  is  used.  The  special  characters  generated  by 
the  lALPHA}[j^  combination  include  Greek  letters  (a,  P,  A,  5,  s,  p,  n,  X,  a,  9,  t,  ro, 
and  n),  other  characters  generated  by  the  Ialpha]1  r*  J  combination  are  \  ,  ', 
=,  <,  >,  /,  ",  \  _,  ~,  !,  ?,  «»,  and  @. 
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Appendix  C 
CAS  settings 

CAS  stands  for  Computer  Algebraic  System.  This  is  the  mathematical  core  of 
the  calculator  where  the  symbolic  mathematical  operations  and  functions  are 
programmed.  The  CAS  offers  a  number  of  settings  can  be  adjusted  according 
to  the  type  of  operation  of  interest.  To  see  the  optional  CAS  settings  use  the 
following: 

•     Press  the        button  to  activate  the  CALCULATOR  MODES  input  form. 

^^^CflLCULflTOR  HOPES 
Optro-tin?  Hojg..niEn3gtB 
nuHb<r  F*rHOt....S'td  _FMj 
HnjU  H«o;ur4....arod; 
C**rd  SyftiH  Rictan^ulor 


FLflGSlCHOOSi  CflSf  DISP  ICflnCLl  OK 


At  the  bottom  of  the  display  you  will  find  the  following  soft  menu  key 
options: 


BiriE-KTIiB! 


Provides  menus  for  manipulating  calculator  flags  (*) 
Lets  the  user  chose  options  in  the  different  fields  in  the  form 
Provides  an  input  form  to  change  CAS  settings 
Provides  an  input  form  to  change  display  settings 
B31135    Closes  this  input  form  and  returns  to  normal  display 
Use  this  key  to  accept  settings 

(*)  Flags  are  variables  in  the  calculator,  referred  to  by  numbers,  which 
can  be  "set"  and  "unset"  to  change  certain  calculator  operating  options. 

Pressing  the  [nxjJ  key  shows  the  remaining  options  in  the  CALCULATOR 
MODES  input  form: 

133^311  Allows  the  user  to  reset  a  highlighted  option 

Closes  this  input  form  and  returns  to  normal  display 
Use  this  key  to  accept  settings 
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To  recover  the  original  menu  in  the  CALCULATOR  MODES  input  box, 
press  the  [hxt]  key.  Of  interest  at  this  point  is  the  changing  of  the  CAS 
settings.  This  is  accomplished  by  pressing  the  EiiSA  soft  menu  key.  The 
default  values  of  the  CAS  setting  are  shov/n  below: 


To  navigate  through  the  many  options  in  the  CAS  MODES  input  form,  use 
the  arrow  keys:  (3D  CD  ■ 

To  select  or  deselect  any  of  the  settings  shown  above,  select  the  underline 
before  the  option  of  interest,  and  toggle  the  i^^lLiiuill!  soft  menu  key  until  the 
right  setting  is  achieved.  When  an  option  is  selected,  a  check  mark  will 
be  shown  in  the  underline  (e.g.,  the  Rigorous  and  Simp  Non-Rational 
options  above).  Unselected  options  will  show  no  check  mark  in  the 
underline  preceding  the  option  of  interest  (e.g.,  the  _Numeric,  _Approx, 
_Complex,  _Verbose,  _Sfep/Step,   Incr  Pow  options  above). 

After  having  selected  and  unselected  all  the  options  that  you  want  in  the 
CAS  MODES  input  form,  press  the  ylilyljlili  soft  menu  key.  This  will  take  you 
back  to  the  CALCULATOR  MODES  input  form.  To  return  to  normal 
calculator  display  at  this  point,  press  the  SESSS  soft  menu  key  once  more. 


Selecting  the  independent  variable 

Many  of  the  functions  provided  by  the  CAS  use  a  pre-determined  independent 
variable.  By  default,  such  variable  is  chosen  to  be  the  letter  X  (upper  case)  as 
shown  in  the  CAS  MODES  input  box  above.  However,  the  user  can  change 
this  variable  to  any  other  letter  or  combination  of  letters  and  numbers  (a 
variable  name  must  start  with  a  letter)  by  editing  the  indep  var  field  in  the 
CAS  MODES  input  box. 
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A  variable  called  VX  exists  in  the  calculator's  {HOME  CASDIR}  directory  that 
takes,  by  default,  the  value  of  'X'.  This  is  the  name  of  the  preferred 
independent  variable  for  algebraic  and  calculus  applications.  For  that  reason, 
most  examples  in  this  Chapter  use  X  as  the  unknown  variable.  If  you  use 
other  independent  variable  names,  for  example,  v/ith  function  HORNER,  the 
CAS  v^ill  not  v/ork  properly. 

The  variable  VX  is  a  permanent  inhabitant  of  the  {HOME  CASDIR}  directory. 
There  are  other  CAS  variables  in  the  {HOME  CASDIR},  e.g.,  REALASSUME 
(131333),  MODULO  CASINFO  (JEBE),  etc. 

You  can  change  the  value  of  VX  by  storing  a  new  algebraic  name  in  it,  e.g., 
'x',  'y',  'm',  etc.  Preferably,  keep  'X'  as  your  VX  variable  for  the  examples  in 
this  manual. 

Also,  avoid  using  the  variable  VX  in  your  programs  or  equations,  so  as  to  not 
get  it  confused  with  the  CAS'  VX.  If  you  need  to  refer  to  the  x-component  of 
velocity,  for  example,  you  can  use  vx  or  Vx. 

Selecting  the  modulus 

The  Modulo  option  of  the  CAS  MODES  input  box  represents  a  number 
(default  value  =  ? 3)  used  in  modular  arithmetic.  More  details  about  modular 
arithmetic  are  presented  elsewhere. 

Numeric  vs.  symbolic  CAS  mode 

When  the  Numeric  CAS  mode  is  selected,  certain  constants  pre-defined  in  the 
calculator  are  displayed  in  their  full  floating-point  value.  By  default,  the 
_Numeric  option  is  unselected,  meaning  that  those  pre-defined  constants  will 
be  displayed  as  their  symbol,  rather  than  their  value,  in  the  calculator  display. 

The  following  screen  shows  the  values  of  the  constant  ;;r(the  ratio  of  the  length 
of  the  circumference  to  its  diameter)  in  symbolic  format  followed  by  the 
numeric,  or  floating-point,  format.  This  example  corresponds  to  the  Algebraic 
operating  mode. 
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•■■n 

TT 

3. 

14159265359 

EDIT  1  VIEH 

RCL 

STO^  |PURGE|CLEflR 

The  same  example,  corresponding  to  the  RPN  operating  mode,  is  shown  next: 


4: 

3: 

2: 

l: 

3. 

14159265359 

EDIT  1  VIEH 

RCL 

STD^  |PURGE|CLEflR 

Approximate  vs.  Exact  CAS  mode 

When  the  _Approx  is  selected,  symbolic  operations  (e.g.,  definite  integrals, 
square  roots,  etc.),  will  be  calculated  numerically.  When  the  _Approx  is 
unselected  (Exact  mode  is  active),  symbolic  operations  will  be  calculated  as 
closed-form  algebraic  expressions,  whenever  possible. 

The  following  screen  shows  a  couple  of  symbolic  expressions  entered  with  an 
active  exact  mode  in  Algebraic  operating  mode: 


LH(2) 

:J5 

J5 

EDIT  1  VIEH  1  RCL 

1  ^^^!^  |PURCE|CLEHR 

In  Algebraic  mode,  the  object  entered  by  the  user  is  shown  in  the  left-hand 
side  of  the  screen,  followed  immediately  by  a  result  in  the  right-hand  side  of 
the  screen.  The  results  shown  above  show  the  symbolic  expressions  for  ln(2), 

i.e.,  the  natural  logarithm  of  2,  andVs,  i.e.,  the  square  root  of  5.  If  the 
_Numeric  CAS  option  is  selected,  the  corresponding  results  for  these 
operations  are  as  follows: 


.69314713056 

:J5 

2.236S679775 

EDIT  1  VIEH 

RCL  1  £TD^  |PURCE|CLEHR 
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The  keystrokes  necessary  for  entering  these  values  in  Algebraic  mode  are  the 
following:  [jfJ_LNlZ2jl]^  CsDCTDt^ 


The  same  calculations  can  be  produced  in  RPN  mode.  Stack  levels  3:  and  4: 
show  the  case  of  Exact  CAS  setting  (i.e.,  the  _Numeric  CAS  option  is 
unselected),  while  stack  levels  ?:  and  2:  show  the  case  in  which  the  Numeric 
CAS  option  is  selected. 


6: 

5: 

4: 

LH(2) 

3: 

J5 

Z: 

.69314713056 

l:   

2.236S679775 

EDIT  1  VIEH 

RCL  1  £T0^  IPURGEICLEHR 

The  required  keystrokes  are:    L  2  JL  r»  J  ln  [  5  ][^  } 

A  keyboard  short  cut  to  toggle  between  APPROX  and  EXACT  mode  is  by 
holding  the  right-shift  key  and  pressing  the  ENTER  key  simultaneously,  i.e., 
□53  (hold) 

Real  numbers  vs.  integer  numbers 

CAS  operations  utilize  integer  numbers  in  order  to  keep  full  precision  in  the 
calculations.  Real  numbers  are  stored  in  the  form  of  a  mantissa  and  an 
exponent,  and  have  limited  precision.  In  APPROX  mode,  however,  whenever 
you  enter  an  integer  number,  it  is  automatically  transformed  into  a  real 
number,  as  illustrated  next: 


:  125. 

125. 

:45. 

45. 

:3. 

 3. 

+^KIP|SKIP-t 

H)EL  1  DEL-f|DEL  L|  inS  ■ 

Whenever  the  calculator  lists  an  integer  value  followed  by  a  decimal  dot,  it  is 
indicating  that  the  integer  number  has  been  converted  to  a  real  representation. 
This  will  indicate  that  the  number  was  entered  while  the  CAS  was  set  to 
APPROX  mode. 
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It  is  recommended  that  you  select  EXACT  mode  as  default  CAS  mode,  and 
change  to  APPROX  mode  if  requested  by  the  calculator  in  the  performance  of 
an  operation. 

For  additional  information  on  real  and  integer  numbers,  as  well  as  other 
calculator's  objects,  refer  to  Chapter  2. 

Complex  vs.  Real  CAS  mode 

A  complex  number  is  a  number  of  the  form  a+bi,  where  /,  defined  by 
—  —1  is  the  unit  imaginary  number  (electrical  engineers  prefer  to  use  the 
symbol  /),  and  a  and  b  are  real  numbers.  For  example,  the  number  2  +  3i  is 
a  complex  number.  Additional  information  on  operations  with  complex 
numbers  are  presented  in  Chapter  4  of  this  guide. 

When  the  _Complex  CAS  option  is  selected,  if  an  operation  results  in  a 
complex  number,  then  the  result  will  be  shown  in  the  form  a+bi  or  in  the  form 
of  an  ordered  pair  (a,b).  On  the  other  hand,  if  the  _Complex  CAS  option  is 
unset  (i.e.,  the  Real  CAS  option  is  active),  and  an  operation  results  in  a 
complex  number,  you  will  be  asked  to  switch  to  Complex  mode.  If  you 
decline,  the  calculator  will  report  an  error. 

Please  notice  that,  in  COMPLEX  mode  the  CAS  is  able  to  perform  a  wider 
range  of  operations  than  in  REAL  mode,  but  it  will  also  be  considerably  slower. 
Thus,  it  is  recommended  that  you  use  the  REAL  mode  as  default  mode  and 
switch  to  COMPLEX  if  requested  by  the  calculator  in  the  performance  of  an 

operation. 

The  following  example  shows  the  calculation  of  the  quantity  yjs^  —  8^  using 
the  Algebraic  operating  mode,  first  with  the  Real  CAS  option  selected.  In  this 
case,  you  are  asked  if  you  want  to  change  the  mode  to  Complex: 


no 

1       1       1  jcnncLl 

OK 
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If  you  press  the  OK  soft  menu  key  (),  tfien  tfie  _Complex  option  is  forced,  and 
tfie  result  is  the  following: 


i-j39 


The  keystrokes  used  above  are  the  following: 


When  asked  to  change  to  COMPLEX  mode,  use:C«D  •  'f  you  decide  not  to 
accept  the  change  to  COMPLEX  mode,  you  get  the  following  error  message: 


Verbose  vs.  non-verbose  CAS  mode 

When  the  _Verbose  CAS  option  is  selected,  certain  calculus  applications  are 
provided  with  comment  lines  in  the  main  display.  If  the  Verbose  CAS  option 
is  not  selected,  then  those  calculus  applications  will  show  no  comment  lines. 
The  comment  lines  will  appear  momentarily  in  the  top  lines  of  the  display 
while  the  operation  is  being  calculated. 

Step-by-step  CAS  mode 

When  the  _Step/sfep  CAS  option  is  selected,  certain  operations  will  be 
shown  step  at  a  time  in  the  display.  If  the  _Step/step  CAS  option  is  not 
selected,  then  intermediate  steps  will  not  be  shown. 


"Mode  switchi  cancel le... 
nriipmnaimaBagwiaiuiHjHiJui 
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For  example,  having  selected  the  Step/step  option,  the  following  screens 

show  the  step-by-step  division  of  two  polynomials,  namely,  (X'^-5X^+3X-2)/(X- 

2).  This  is  accomplished  by  using  function  DIV2  as  shown  below.  Press  [inter] 

to  show  the  first  step:   

Division  H=BQ-hR 
fl:  tl,-5,3,-£J 

B:  tl,-2> 
Q:  Hi 

R:  {:-3,3,-2J 
Press  a  key  to  go  on 


+^KIP|SKIP-H  H)EL  I  DEL-f|DEL  L|  inS  ■ 


D I V2  ( X-^3-5*X-^2+3*X-2 , 


k£KIP|£KIP-H +«EL  I  DEL-»|DEL  L|  in£  ■ 


The  screen  inform  us  that  the  calculator  is  operating  a  division  of  polynomials 
A/B,  so  that  A  =  BQ  +  R,  where  Q  =  quotient,  and  R  =  remainder.  For  the 
case  under  consideration,  A  =  X"^-5X^-f3X-2,  and  B  =  X-2.  These  polynomials 
are  represented  in  the  screen  by  lists  of  their  coefficients.  For  example,  the 
expression  A:  {1,-5,3,-2}  represents  the  polynomial  A  =  X'^-5X^-i-3X-2,  B:{l,-2} 
represents  the  polynomial  B  =  X-2,  Q:  {1}  represents  the  polynomial  Q  =  X, 
and  R:{-3,3,-2}  represents  the  polynomial  R  =  -3X^-i-3X-2. 

At  this  point,  press,  for  example,  the  Iinter)  key.  Continue  pressing  Ienter)  the  key 
to  produce  additional  steps: 


Division  H=BQ-hR 
fl:  tl,-5,3,-2J 

B:  tl,-2> 
Q:  {:ii-3J 
R:  {:-3,-2J 

Press  a  key  to  go  on 

^iyision  H=BQ-hR 
fl:  tl,-5,3,-2J 

3:  tl,-2> 
a:  {:i,-3,-3J 
R:  t-SJ 

=ress  a  key  to  go  on 

+^KIP|SKIP-H  H)EL  1  DEL-f|DEL  L|  inS  ■ 

+^KIP|SKIP-H  H)EL  1  DEL-f|DEL  L|  inS  ■ 

:  DI  V2(x^-5.X^-H3.X-2,X-2) 
{q:(x^-3'X-3)  R:(-S)} 


+^KIP|SKIP-H  H)EL  I  DEL-f|DEL  L|  inS  ■ 


Thus,  the  intermediate  steps  shown  represent  the  coefficients  of  the  quotient 
and  residual  of  the  step-by-step  synthetic  division  as  would  have  been 
performed  by  hand,  i.e., 

-5X^  +3X-2  -3X'+3X-2 

 =  X  +  = 

X-2  X-2 
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3X-2 


=  X'  -3X-3X- 


8 


X-2 


X-2 


Increasing-power  CAS  mode 

When  the  _/ncr  pow  CAS  option  is  selected,  polynomials  will  be  listed  so  that 
the  terms  will  have  increasing  powers  of  the  independent  variable.  If  the  _/ncr 
pow  CAS  option  is  not  selected  (default  value)  then  polynomials  will  be  listed 
so  that  the  terms  will  have  decreasing  powers  of  the  independent  variable. 
An  example  is  shown  next  in  Algebraic  mode: 


In  the  first  case,  the  polynomial  (X+3)^  is  expanded  in  increasing  order  of  the 
powers  of  X,  while  in  the  second  case,  the  polynomial  shows  decreasing 
order  of  the  powers  of  X.  The  keystrokes  in  both  cases  are  the  following: 


In  the  first  case  the  _/ncr  pow  option  was  selected,  while  in  the  second  it  was 
not  selected.  The  same  example,  in  RPN  notation,  is  shown  below: 


The  same  keystroke  sequence  was  used  to  produce  each  of  these  results: 

CZD  CS) S  CiD  CX)  CD  C3  CS  S  [^D 

Rigorous  CAS  setting 


:  (X+3)^ 

1 5.x'^+90.X^+270.X^+4(J 


ED (3  CB  QD  CD  CZD  CX]  ^ 


\  243+405.X+270.X^+90.X^ 
■  X^+15.x'^+90.X^+270.X^^ 
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when  the  Rigorous  CAS  option  is  selected,  the  algebraic  expression  jXj, 
i.e.,  the  absolute  value,  is  not  simplified  to  X.  If  the  _Rigorous  CAS  option  is 
not  selected,  the  algebraic  expression  jXj  is  simplified  to  X. 

The  CAS  can  solve  a  larger  variety  of  problems  if  the  rigorous  mode  is  not  set. 
Hov/ever,  the  result,  or  the  domain  in  which  the  result  are  applicable,  might 
be  more  limited. 

Simplify  non-rational  CAS  setting 

When  the  _Simp  Non-Rational  CAS  option  is  selected,  non-rational 
expressions  v^ill  be  automatically  simplified.  On  the  other  hand,  if  the  _Simp 
Non-Rational  CAS  option  is  not  selected,  non-rational  expressions  will  not  be 
automatically  simplified. 

Using  the  CAS  HELP  facility 

Turn  on  the  calculator,  and  press  the  [rooQ  key  to  activate  the  TOOL  menu. 
Next,  press  the  (JL)  soft  menu  key,  followed  by  the  [inter}  key  (the  key  in  the 
lowest  right  corner  of  the  keyboard),  to  activate  the  HELP  facility.  The  display 
will  look  as  follows: 


HECUV 

flcosas 

HDDTHOD 

HDDTOREAL 

HEL 

ALGE 

1       1       1  IcnncL 

OK 

At  this  point  you  will  be  provided  with  a  list  of  all  CAS  commands  in 
alphabetical  order.  You  can  use  the  down  arrow  key,  '^j?,  to  navigate 
through  the  list.  To  move  upwards  in  the  list  use  the  up  arrow  key,  .  The 
arrow  keys  are  located  on  the  right-hand  side  of  the  keyboard  between  the 
first  and  fourth  rows  of  keys. 

Suppose  that  you  want  to  find  information  on  the  command  ATAN2S 
(ArcTANgent-to-Sine  function).    Press  the  down  arrow  key,  until  the 

command  ATAN2S  is  highlighted  in  the  list: 
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HLGE 

HRIT 

:HE 

0. 

HEL 

ATAna;  II 

Notice  that,  in  this  instance,  soft  menu  keys  (JL)  and  (JL)  ore  the  only  one 
with  associated  commands,  namely: 

ifl3I!fl3    (jT)      CANCeL  the  help  facility 

■Elonl    (jL)      OK  to  activate  help  facility  for  the  selected  command 

If  you  press  the  ISIIlIiISI jl  key,  the  HELP  facility  is  skipped,  and  the  calculator 
returns  to  normal  display. 

To  see  the  effect  of  using  in  the  HELP  facility,  let's  repeat  the  steps  used 

above  from  to  the  selection  of  the  command  ATAN2S  in  the  list  of  CAS 
commands:  EEiaiiC«D(^)  ...(10  times) 

Then,  press  the  MSM r»~]  key  to  obtain  information  about  the  command 
ATAN2S. 

The  help  facility  indicates  that  the  command,  or  function,  ATAN2S  replaces 
the  value  of  atan(x),  the  arc  tangent  of  a  value  x,  by  its  equivalent  in  terms  of 
the  function  asin  (arcsine),  i.e.. 

The  fourth  and  fifth  lines  in  the  display  provide  an  example  of  application  of 
the  function  ATAN2S.  Line  four,  namely,  ATAN2S(ATAN(X)),  is  the  statement 
of  the  operation  to  be  performed,  v/hile  line  five,  namely,  ASIN(X/V(X'^2+1 )), 
is  the  result. 

The  bottom  line  in  the  display,  starting  v/ith  the  particle  See:,  is  a  reference 
line  listing  other  CAS  commands  related  to  the  command  ATAN2S. 

Notice  that  there  are  six  commands  associated  v/ith  the  soft  menu  keys  in  this 
case  (you  can  check  that  there  are  only  six  commands  because  pressing  the 
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[nxtJ  produces  no  additional  menu  items).  The  soft  menu  key  commands  are 
the  following: 


dD  EXIT  the  help  facility 

Ifflllil     QD  Copy  the  example  command  to  the  stack  and  exit 

liliiS  rra~]  See  the  first  link  (if  any)  in  the  list  of  references 

iEiiiiil  See  the  second  link  (if  any)  of  the  list  of  references 

mSM   (JL)  See  the  third  link  (if  any)  of  the  list  of  references 

EEiilll     QT)  Return  to  the  MAIN  command  list  in  the  help  facility 


In  this  case  we  want  to  ECHO  the  example  into  the  stack  by  pressing 
ESSE  r«~] .  The  resulting  display  is  the  following: 


:HELP 

0. 

:HELP 

:  RTRH2S[RTRH[X)] 

CHICHI  HELP  1         1         1  1 

There  are  now  four  lines  of  the  display  occupied  with  output.  The  first  two 
lines  from  the  top  correspond  to  the  first  exercise  with  the  HELP  facility  in 
which  we  cancel  the  request  for  help.  The  third  line  from  the  top  shows  the 
most  recent  call  to  the  HELP  facility,  while  the  last  line  shows  the  ECHO  of  the 
example  command.  To  activate  the  command  press  the  [fAmaj  key.  The  result 
is: 


:HELP 

:  RTRH2S(RTRH(X)5 

RSIH 

0. 

[      X  1 

CHICHI  HELP  1         1         1  1 

Notice  that,  as  new  lines  of  output  are  produced,  the  display  (or  stack)  pushes 
the  existing  lines  upwards  and  fills  the  bottom  of  the  screen  with  more  output. 

The  HELP  facility,  described  in  this  section,  will  be  very  useful  to  refer  to  the 
definition  of  the  many  CAS  commands  available  in  the  calculator.  Each  entry 
in  the  CAS  help  facility,  whenever  appropriate,  will  have  an  example  of 
application  of  the  command,  as  well  as  references  as  shown  in  this  example. 
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To  navigate  quickly  to  a  particular  command  in  the  help  facility  list  without 
having  to  use  the  arrow  keys  all  the  time,  we  can  use  a  shortcut  consisting  of 
typing  the  first  letter  in  the  command's  name.  Suppose  that  we  want  to  find 
information  on  the  command  IBP  (Integration  By  Parts),  once  the  help  facility 
list  is  available,  use  the  I^ha)  key  (first  key  in  the  fourth  row  from  the  bottom  of 
the  keyboard)  followed  by  the  key  for  the  letter  i  (the  same  as  the  key  iroctj) , 
i.e.,  iALPHA)(Tj .  This  will  take  you  automatically  to  the  first  command  that  starts 
with  an  /,  namely,  IBASIS.  Then,  you  can  use  the  down  arrow  key  "^3?  , 
twice,  to  find  the  command  IBP.  Pressing  the         fTT]  key,  we  activate  the 
help  facility  for  this  command.    Press  SUSjCK]]  to  recover  the  main  list  of 
commands,  or  ilB[3ilCZD  to  exit  the  facility. 

References  for  non-CAS  commands 

The  help  facility  contains  entries  for  all  the  commands  developed  for  the  CAS 
(Computer  Algebraic  System).  There  is  a  large  number  of  other  functions  and 
commands  that  were  originally  developed  for  the  HP  48G  series  calculators 
that  are  not  included  in  the  help  facility.  Good  references  for  those 
commands  are  the  HP  48G  Series  user's  guide  (HP  Part  No.  00048-90126) 
and  the  HP  48G  Series  Advanced  User's  Reference  Manual  (HP  Part  No. 
00048-90136)  both  published  by  Hewlett-Packard  Company,  Corvallis, 
Oregon,  in  1 993. 

CAS  End  User  Term  and  Conditions 

Use  of  the  CAS  Software  requires  from  the  user  an  appropriate  mathematical 
knowledge.  There  is  no  warranty  for  the  CAS  Software,  to  the  extent  permitted 
by  applicable  law.  Except  when  otherwise  stated  in  writing  the  copyright 
holder  provides  the  CAS  Software  "As  Is"  without  warranty  of  any  kind,  either 
expressed  or  implied,  including,  but  not  limited  to,  the  implied  warranties  of 
merchantability  and  fitness  for  a  particular  purpose.  The  entire  risk  as  to  the 
quality  and  performance  of  the  CAS  Software  is  with  you.  Should  the  CAS 
Software  prove  defective,  you  assume  the  cost  of  all  necessary  servicing, 
repair  or  correction. 
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In  no  event  unless  required  by  applicable  law  will  any  copyright  holder  be 
liable  to  you  for  damages,  including  any  general,  special,  incidental  or 
consequential  damages  arising  out  of  the  use  or  inability  to  use  the 
CAS  Software  (including  but  not  limited  to  loss  of  data  or  data  being  rendered 
inaccurate  or  losses  sustained  by  you  or  third  parties  or  a  failure  of  the  CAS 
Software  to  operate  with  any  other  programs),  even  if  such  holder  or  other 
party  has  been  advised  of  the  possibility  of  such  damages.  If  required  by 
applicable  law  the  maximum  amount  payable  for  damages  by  the  copyright 
holder  shall  not  exceed  the  royalty  amount  paid  by  Hewlett-Packard  to  the 
copyright  holder  for  the  CAS  Software. 
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Appendix  D 
Additional  character  set 

While  you  can  use  any  of  the  upper-case  and  lower-case  English  letter  from 
the  keyboard,  there  are  255  characters  usable  in  the  calculator.  Including 
special  characters  like  0,  X,  etc.,  that  that  can  be  used  in  algebraic 
expressions.  To  access  these  characters  we  use  the  keystroke 
combination  {^^am  (associated  with  the  EVAL  key).  The  result  is  the 
following  screen: 


 4"  

 41  

!  "#*::S:'  <>*+,-.  ^ 

ai234567S9:i<=>? 
ERBCDEFGHUKLMHO 
PQRSTUVWXYZ[\]-^_ 
abcdef  gtiiJk  Imrio 


By  using  the  arrow  keys,  CJDCD'^^^^/  we  can  navigate  through  the 
collection  of  characters.  For  example,  moving  downwards  in  the  screen 
produces  more  characters  in  the  display: 


pqrstuywxyzt  I  J'-^ 

ai-t£H!i!i*"ea-K--e" 


HODIF  ECHOl  ECHO 


Moving  farther  down,  we  see  these  characters: 


f:it£H!|il*"ea-s--e" 

■■±23  'uH-  l2S-!^liJ^i 
SIriooooo-Suuuuyp  y 


HODIF  ECHOl  ECHO 


There  will  be  one  character  highlighted  at  all  times.  The  lower  line  in  the 
display  will  show  the  short  cut  for  the  highlighted  character,  as  well  as  the 
ASCII  character  code  (e.g.,  see  the  screen  above:  the  short  cut  is  a*nDar-»9, 
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i.e.,  (4^lJnJ(5)(4™)Lr!JL?J,  and  the  code  is  240).   The  display  also  shows 
three  functions  associated  with  the  soft  menu  keys,  f4,  f5,  and  f6.  These 
functions  ore: 

iliniLlljlil:   Opens  a  graphics  screen  where  the  user  can  modify  highlighted 


character.  Use  this  option  carefully,  since  it  will  alter  the  modified  character 
up  to  the  next  reset  of  the  calculator.  (Imagine  the  effect  of  changing  the 
graphic  of  the  character  ^  to  look  like  a  2!). 

Copies  the  highlighted  character  to  the  command  line  or  equation 
writer  (EQW)  and  exits  the  character  set  screen  (i.e.,  echoes  a  single 
character  to  the  stack). 

oIuIlI:  Copies  the  highlighted  character  to  the  command  line  or  equation  writer 
(EQW),  but  the  cursor  remains  in  the  character  set  screen  to  allow  the  user  to 
select  additional  characters  (i.e.,  echoes  a  string  of  characters  to  the  stack). 
To  exit  the  character  set  screen  press  \ 

For  example,  suppose  you  have  to  type  the  expression;        +  2^  +  5 

Here  is  a  suggested  approach,  using  the  stack  in  either  Algebraic  or  RPN 
mode: 

Use  the  keystrokes:  CDCED  ™^  to  get  to  the  characters  screen.  Next,  use  the 
arrow  keys  to  highlight  the  character  X.  Press  iBiiuEO  (i.e.,  the  f"""!  key),  and 
continue  with  the  keystrokes:  I  +  J  [  2  J  [  x  J(.    J  chars^  .  Next,  use  the  arrow 
keys  to  highlight  the  character  |a.  Press  iCESEt!!  (i.e.,  the        key),  and  finish 
the  expression  with  the  keystrokes:  I  +  Jl  5  }[enter)  .  Here  is  the  result  of  this 
exercise  in  Algebraic  and  RPN  modes,  respectively: 


^.+2'ut+5 


Following,  we  list  some  of  the  most  common  Ialpha]  [    J  keystroke  combinations: 
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Greek  letters 


a 

(alpha) 

P 

(beta) 

5 

(delta) 

E 

(epsilon) 

e 

(theta) 

X 

(lambda) 

[ALPHA}Cr^(N] 

(mu) 

[ALPHA]  Cr^(M] 

p 

(rho) 

[ALPHA]  lji>J(Ti 

a 

(sigma) 

(AmjA}{j^(J] 

X 

(tau) 

[alpha]  fr^  (U] 

CO 

(omega) 

A 

(upper-case  delta) 

n 

(upper-case  pi) 

Other  characters 

(tilde) 


!  (factorial) 

?  (question  mark)  ) 

\  (backward  slash) 

i£  (angle  symbol) 

@  (at) 


[alpha]  [j^l_2_) 


Some  characters  commonly  used  that  do  not  have  simple  keystroke  shortcuts 
are:  x  (x  bar),  y  (gamma),  ri  (eta),  Q  (upper-case  omega).  These  characters 
can  be  "echoed"  from  the  CHARS  screen:  CS  owss . 
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Appendix  E 

The  Selection  Tree  in  the  Equation  Writer 

The  expression  tree  is  a  diagram  showing  how  the  Equation  Writer  interprets 
an  expression.   The  form  of  the  expression  tree  is  determined  by  a  number  of 
rules  known  as  the  hierarchy  of  operation.   The  rules  are  as  follows: 

1 .  Operations  in  parentheses  are  executed  first,  from  the  innermost  to 
the  outermost  parentheses,  and  from  left  to  right  in  the  expression. 

2.  Arguments  of  functions  are  executed  next,  from  left  to  right. 

3.  Functions  are  executed  next,  from  left  to  right. 

4.  Powers  of  numbers  are  executed  next,  from  left  to  right. 

5.  Multiplications  and  divisions  are  executed  next,  from  left  to  right. 

6.  Additions  and  subtraction  are  executed  last,  from  left  to  right. 

Execution  from  left  to  right  means  that,  if  two  operations  of  the  same  hierarchy, 
say  two  multiplications,  exist  in  an  expression,  the  first  multiplication  to  the  left 
will  be  executed  before  the  second,  and  so  on. 

Consider,  for  example,  the  expression  shown  below  in  the  equation  writer: 


CClj-3>x+5).[x^+4] 
SIHC4-X-24) 


EDIT  I  CUR£  I  EIG  ■!  EVHL  |FHCTO|  £IHP 


The  insertion  cursor  {^)  at  this  point  is  located  to  the  right  of  the  2  in  the 
argument  of  the  SIN  function  in  the  denominator.  Press  the  down  arrow  key 
to  trigger  the  clear,  editing  cursor  (□)  around  the  2  in  the  denominator. 
Next,  press  the  left  arrow  key  CT),  continuously,  until  the  clear,  editing  cursor 
is  around  the  y  in  the  first  factor  in  the  denominator.  Then,  press  the  upper- 
arrow  key  to  activate  the  selection  cursor  (■]  around  the  y.  By  pressing  the 
upper  arrow  key       ,  continuously,  we  can  follow  the  expression  tree  that  will 
take  use  from  the  y  to  the  completion  of  the  expression.  Here  is  the  sequence 
of  operations  highlighted  by  the  upper  arrow  keyt"^  : 
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Step  A1   Step  A2 


C(ni-3).x+5){x^+4) 

Step  A3 


Step  A4 


Step  A5 


CCy-3).x+5).(x^+4j 


SIHC4.X-2) 


EDIT   CURS   EIG  ■  EVflL  FflCTO  SIMP 


Step  A6 


We  notice  the  application  of  the  hierarchy-of-operation  rules  in  this  selection. 
First  the  y  (Step  Al ).  Then,  y-3  (Step  A2,  parentheses).  Then,  (y-3)x  (Step  A3, 
multiplication).  Then  (y-3)x+5,  (Step  A4,  addition).  Then,  ((y-3)x+5)(x^+4) 
(Step  A5,  multiplication),  and  finally,  ((y-3)x+5)(x2+4)/SIN(4x-2)  (Step  A6, 
division).  It  is  important  to  point  out  that  the  multiplication  in  Step  A5  includes 
the  first  term,  ((y-3)x+5)  with  a  second  term  (x^+4),  which  is  already 
calculated.  To  see  the  steps  in  calculating  these  second  term,  press  the  down 
arrow  key         continuously,  until  the  clear,  editing  cursor  is  triggered  around 
the  y,  once  more.  Then,  press  the  right  arrow  key  until  these  cursor  is  over  the 
x  in  the  second  term  in  the  numerator.  Then,  press  the  upper-arrow  key  to 
select  this  x.  The  steps  in  the  evaluation  of  the  expression,  starting  from  this 
point,  are  shown  below: 
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Step  B1  

CCLj-3>x+5).tf+4] 


EDIT  I  CUR£  I  EIG  ■!  EVHL  |FHCTO|  £IHP 


Step  B2  

CClj-3).x+5).[B-4] 


EDIT  I  CUR£  I  eiG  ■!  EVHL  |FHCTO|  ilW 


Step  B3  

CCLj-3>x+5).[Si] 

SIHC+x-2) 


EDIT  I  CUR£  I  EIG  ■!  EVHL  |FHCTD|  £IHP 


Step  B4  =  Step  A5 


SIHC+x-2) 


EDIT  I  CUR£  I  DIG  ■!  EVHL  |FHCTD|  ilW 


Step  B5  =  Step  A6 


m 

SIHC+x- 

EDIT  I  CUR£  I  EIG  ■!  EVHL  |FHCTD|  £IHF 


We  can  also  follow  the  evaluation  of  the  expression  starting  from  the  4  in  the 
argument  of  the  SIN  function  in  the  denominator.  Press  the  down  arrow  key 

,  continuously,  until  the  clear,  editing  cursor  is  triggered  around  the  y, 
once  more.  Then,  press  the  right  arrow  key  until  these  cursor  is  over  the  4  in 
the  denominator.  Then,  press  the  upper-arrow  key  (^A^to  select  this  4.  The 
steps  in  the  evaluation  of  the  expression,  starting  from  this  point,  are  shown 
below: 


Step  CI   Step  C2 


CCy-3>x+5).(x^+4) 

CCy-3).x+5).(x^+4) 

SIH(E}x-£) 

SIH(EH-£) 

EDIT  1  CURS  1  EIG  -\  EVHL  |FHCTD|  SIMP 

EDIT  1  CURS  1  RIG  -\  EVHL  |FHCTD|  SIMP 
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Step  C3 


CClj-3>x+5).[x^+4] 


Step  C4 


SIHC4.X-2) 


EDIT   CUR£   EIG  ■  EVHL  FHCTO  £IHP  H  EDIT   CUR£   DIG  ■  EVHL  FHCTD  £IHP 


Step  C5  =  Step  B5  =  Step  A6 


CCy-3>x+5).(x^+4j 


SIHC4.X-2) 


EDIT   CURS   EIG  ■  EVflL  FflCTD  SIMP 


The  expression  tree  for  the  expression  presented  above  is  shown  next: 


A6  (7)  B5,C5 


The  steps  in  the  evaluation  of  the  three  terms  (Al  through  A6,  Bl  through  B5, 
and  CI  through  C5)  are  shov/n  next  to  the  circle  containing  numbers, 
variables,  or  operators. 
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Appendix  F 

The  Applications  (APPS)  menu 

The  Applications  (APPS)  menu  is  available  through  the  Iapps]  key  (first  key  in 
second  row  from  the  keyboard's  top).   The  [appsj  key  shows  the  following 
applications: 


l^<)  func'ti*nf.. 
C^nitiriti  lib.. 

TiH«  &  iiti.. 


5.TiH«  &  iits.. 


The  different  applications  are  described  next. 


Plot  functions.. 

Selecting  option  7.  Plof  functions.,  in  the  APPS  will  produce  the  following 
menu  list  of  graph-related  options: 


l.Eouo-ti^n  «n-try..  1 

2. put  HindoH.. 
^.Groph  difpUy.. 
H.Plot  fstup.. 
5.Tobl<  istuf.. 
S.T4bl.«  difpld^.. 

1       1       1  icflncLl 

OK 

The  six  options  shown  are  equivalent  to  the  keystroke  sequences  listed  below: 

Equation  entry...  UjJJ^  Plot  window..  Ijnj  jw_ 

Graph  display..  CSD^^w  Plot  setup..  CfDi™, 

Table  setup..  C5D!Mr  Table  display..  C5Di!«^ 

These  applications  are  presented  in  detail  in  Chapter  1  2. 
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I/O  functions.. 

Selecting  option  2.  I/O  funciions..  in  the  APRS  menu  will  produce  the 
following  menu  list  of  input/output  functions 


l.S«nd  t*  HP  HS.. 


l.Get  fr*H  HP  HS 
3. Print  difpUy 
H. Print.. 
5.Tronff<r.. 
fi. Start  S«ru«r 


These  applications  are  described  next: 


Send  to  HP  49.. 
Get  from  HP  49 
Print  display 
Print.. 
Transfer.. 
Start  Server.. 


Send  data  to  another  calculator 

Receive  data  from  another  calculator 

Send  screen  to  printer 

Print  selected  object  from  calculator 

Transfer  data  to  other  device 

Calculator  set  as  a  server  for  communication  with 

computers 


Constants  lib.. 

Selecting  option  3.  Constants  lib.,  in  the  APPS  menu  opens  the  Constant 
Library  application  that  provides  values  of  standard  physical  constants: 


consTflnrs  lierhrv 


HR:  RyoQadro  s  number 


k:  Eoltzmann 
Vm:  molar  volume 
R:  universal  gas 
StdT:  std  temperature 
StdP:  std  pressure  1 


SI    EHGLi  UniTS  VHLUE  -(STK  KUIT 


The  Constants  Library  is  discussed  in  detail  in  Chapter  3. 
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Numeric  solver.. 

Selecting  option  3.  Constants  lib.,  in  the  APRS  menu  produces  the  numerical 
solver  menu: 


diff  It.. 
3.S*lu<  poly.. 
H. Solus  lin  s])s.. 
5. Solus  financs.. 
S.HSLV 

1     1     1  1 

CflnCLl 

UK 

This  operation  is  equivalent  to  the  keystroke  sequence  [  r»  )mjm.slv  .  The 
numerical  solver  menu  is  presented  in  detail  in  Chapters  6  and  7. 

Time  &  date.. 

Selecting  option  5.Time  &  date.,  in  the  APRS  menu  produces  the  time  and 
date  menu: 


ll.EroHJS  jljfHj.. 


a.sst  oiofH.. 
j.sst  tiHSj  dots.. 

H. Too  If.. 


ICHnCLl  UK 


This  operation  is  equivalent  to  the  keystroke  sequence  I  r>  J  time  .  The  time  and 
date  menu  is  presented  in  detail  in  Chapter  26. 

Equation  writer.. 

Selecting  option  6. Equation  writer.,  in  the  APRS  menu  opens  the  equation 
v/riter: 


4 


EDIT  I  CURS  I  EIG  ■!  EVHL  |FHCTU|  SIHP 
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This  operation  is  equivalent  to  the  keystroke  sequence  (j^l  eqw  .  The  equation 
writer  is  introduced  in  detail  in  Chapter  2.  Examples  that  use  the  equation 
writer  are  available  throughout  this  guide. 


File  manager.. 

Selecting  option  /.File  manager.,  in  the  APRS  menu  launches  the  file  manager 
application: 


L:ERAH 

3:FLA£H  SIEKE 
HAn^ 

fUTPEC 


This  operation  is  equivalent  to  the  keystroke  sequence  (.  *i  )RL£s  .The  file 
manager  is  introduced  in  Chapter  2. 


Matrix  Writer.. 

Selecting  option  8. Matrix  Writer.,  in  the  APRS  menu  launches  the  matrix 
writer: 


This  operation  is  equivalent  to  the  keystroke  sequence  [  <n  )mtrw  .The  Matrix 
Writer  is  presented  in  detail  in  Chapter  10. 
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Text  editor.. 

Selecting  option  9.Text  editor.,  in  the  APRS  menu  launches  the  line  text  editor: 


The  text  editor  can  be  started  in  many  cases  by  pressing  the  down-arrow  key 
"^3?  .    If  the  object  in  the  display  is  an  algebraic  object,  pressing  will 
most  likely  start  the  Equation  Writer.  The  text  editor  is  introduced  in  Chapter 
2,  and  presented  in  detail  in  Appendix  L. 

Math  menu  .. 

Selecting  option  10. Math  menu.,  in  the  APRS  menu  produces  the  MTH 
(mathematics)  menu: 


HHTH  HEnU 

1.  VECTOR..  1 

2.  HATRIK.. 

3.  LIST.. 
H.HYPEREOLIC. 
5.  REAL.. 
e.EASE.. 

1    1  1 

ICAnCL 

OK 

HATH  HERU 

G.BASE.. 

?.PRORARILITV.. 

S.FFT.. 

S.COHPLEK.. 

ID-COnSTARTS.. 

11. SPECIAL  FuncTions..  1 

1         1         1  ICARCL 

OH 

This  operation  is  equivalent  to  the  keystroke  sequence  [jjJmth_  .  The  MTH 
menu  is  introduced  in  Chapter  3  (real  numbers).  Other  functions  from  the 
MTH  menu  are  presented  in  Chapters  4  (complex  numbers),  8  (lists),  9 
(vectors),  1  0  (matrix  creation),  1  1  (matrix  operation),  1 6  (fast  Fourier 
transforms),  1 7  (probability  applications),  and  1 9  (numbers  in  different  bases). 
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CAS  menu.. 

Selecting  option  7  7. CAS  menu.,  in  the  APRS  menu  produces  the  CAS  or 
SYMBOLIC  menu: 


ens  HEnu 

1. ARITHMETIC.  II 

a.ALGEERA..  1 

COMPLEX..  1 

H.  CALCULUS..  1 

5.EKP.  S:  LA... 

e. SYMBOLIC  SOLVER..  U 

1       1       1  IcflncLl 

OK 

CAS  MEAU 

H. CALCULUS..  n 

5. EXP.  &  Ln... 

E.SYMPOLIC  SOLVER..  | 

7. MATRICES..  1 

S.COAVERT..  1 

^.TRIGOnOHETRIC.          I  I 

1         1         1  jCAACLl 

OK 

This  operation  is  also  available  by  pressing  the  [msJ  key.  The  CAS  or 
SYMBOLIC  menu  is  introduced  in  Chapter  5  (algebraic  and  arithmetic 
operations).  Other  functions  from  the  CAS  menu  are  presented  in  Chapters  4 
(complex  numbers),  6  (equations  solutions),  1 0  (matrix  creation),  1  1  (matrix 
operation),  13  (calculus),  14  (multivariate  calculus),  and  15  (vector  analysis). 


Page  F-6 


Appendix  G 
Useful  shortcuts 

Presented  herein  are  a  number  of  keyboard  shortcuts  commonly  used  in  the 
calculator: 

•  Adjust  display  contrast:  C°D  (hold)  FF),  or  (^D  (hold)  GiD 

•  Toggle  between  RPN  and  ALG  modes:  [modeJ[  +/-  jgEB  or 
{mode}  [  +/-  ]  [enter]  . 

•  Set/clear  system  flog  95  (ALG  vs.  RPN  operating  mode) 

•  In  ALG  mode, 

CF(-95)  selects  RPN  mode 

•  In  RPN  mode, 

95  I  +1-  ][ENTER)  SF  selects  ALG  mode 

■     A  keyboard  short  cut  to  toggle  between  APPROX  and  EXACT  mode  is 
by  holding  the  right-shift  key  and  pressing  the  ENTER  key 
simultaneously,  i.e.,       I  r>  J  (hold)  (pifmj . 

•  Set/clear  system  flag  1 05  (EXACT  vs.  APPROX  CAS  mode) 

(S)  sa33§^(3D^:^CHD^^  II^JEia 

•  In  ALG  mode, 

SF(-1 05)  selects  APPROX  CAS  mode 
CF(-105)  selects  EXACT  CAS  mode 

•  In  RPN  mode, 

1 05  SF  selects  APPROX  CAS  mode 

105  Gr)(«^  CF  selects  EXACT  CAS  mode 


Page  G-1 


Set/clear  system  flag  1 17  (CHOOSE  boxes  vs.  SOFT  menus): 

•  In  ALG  mode, 

SF(-1  1 7)  selects  SOFT  menus 
CF(-1 1 7)  selects  CHOOSE  BOXES. 

•  in  RPN  mode, 

1 1 7  [  +/-  )fjNm]  SF  selects  SOFT  menus 
1 1 7  [  +/-  )[ENTER}  CF  selects  SOFT  menus 

Change  angular  measure: 

o  To  degrees:  [alpha} [alpha]  (d}(e](S}  [enter] 
o    To  radian:  (^Z^(^™)(gg](g)(^) 

Special  characters: 

o    Angle  symbol  (Z):  (^^CSCTD 

o    Factorial  symbol  (!):  td™]C23L2J 

o    Degree  symbol  (°):  (^CB{hold)C6l] 

Lock/unlock  alpha  keyboard: 

o     Lock  alpha  keyboard  (upper  case):  [alpha] [alpha] 

o    Unlock  alpha  keyboard  (upper  case): 

o    Lock  alpha  keyboard  (lower  case):  [alpha] [alpha] p=n [alpha] 

o    Unlock  alpha  keyboard  (lower  case):  I  <n  ][ALPHA][AiM] 


•     Greek  letters: 
Alpha  (a): 
DELTA  (A): 
Epsilon  (e): 
Mu  (^i): 
PI  (n): 
Theta  (0): 
Omega  (co): 


[ALPHA][ji>J(J} 

[alpha][^(m] 
[alpha][j^0 


Beta  (P): 
Delta  (d): 
Rho  (p): 
Lambda  (A,): 
Sigma  (ct): 
Tau  (t): 


[alpha]  [r^  ](Di 

[ALPHA](J^(f] 
[ALmA][JfJ(N] 
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•  System-level  operation  (Hold  I    J,  release  it  after  entering  second  or 
third  key): 

o  (hold)  (jO  (jD  '■  "Cold"  restart  -  all  memory  erased 

o    LonJ  (hold)  (jiJ  :  Cancels  keystroke 

o    [  ON  J  (hold)        :  "Warm"  restart  -  memory  preserved 

o    L  ON  J  (hold)  (jD  '■  Starts  interactive  self-test 

o    LpaJ  (hold)  C2D  '■  Starts  continuous  self-test 

o    [onJ  (hold)  IjkJ  ;  Deep-sleep  shutdown  -  timer  off 

o    I    J  (hold)  CjQ  :  Performs  display  screen  dump 

o    L  ON  J  (hold)  C«3  :  Cancels  next  repeating  alarm 

•  Menus  not  accessible  through  keyboard:  In  RPN,  enter  menu_number, 
type  MENU.  In  ALG  mode,  type  MENU(menu_number). 
Menu_number  is  one  of  the  following: 

o  STAT  soft  menu:  96 
o    PLOT  soft  menu:  81 


o  SOLVE  soft  menu: 
o    UTILITY  soft  menu: 


74,  or  use  CED  (hold)  CZD 
113 


•     Other  menus: 


o    MATHS  menu:  (AiM}(AiMAj(^ 

o    MAIN  menu:  (^Z™](^™](g(3(3(g(fN7H) 


Other  keyboard  short  cuts: 


o  CB(hold)CZD 
o    [jT]  (hold)  (mode 


SOLVE  menu  (menu  74) 
PRG/MODES  menu  (Chapter  21) 
Starts  text  editor  (Appendix  L) 
HOME(),  go  to  HOME  directory 


o 


o  CfD  (hold)  ™L 

o  QD  (hold) 

o  CS  (hold)  ^ 

o  CgD(hold)cww 


Recover  last  active  menu 

List  contents  of  variables  or  menu  entries 


PRG/CHAR  menu  (Chapter  21 ) 
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Appendix  H 

The  CAS  help  facility 

The  CAS  help  facility  is  available  through  the  keystroke  sequence  (.rooij 
[wxrJIujjj-Si  [entek]  .  The  following  screen  shots  show  the  first  menu  page  in  the 
listing  of  the  CAS  help  facility. 


HECUV 

flcosas 

HDDTHOD 

HDDTOREAL 

HEL 

1       1       1  IcflncL 

OK 

The  commands  are  listed  in  alphabetical  order.  Using  the  vertical  arrow 
keys  i^^'^y?  one  can  navigate  through  the  help  facility  list.    Some  useful 
hints  on  navigating  through  this  facility  are  shown  next: 

•  You  can  hold  down  the  down  arrow  key        and  watch  the  screen 
until  the  command  you're  looking  for  shows  up  in  the  screen.  At  this 
point,  you  can  release  the  down  arrow  key.  Most  likely  the  command 
of  interest  will  not  be  selected  at  this  point  (you  may  overshoot  or 
undershoot  it).  However,  you  can  use  the  vertical  keys  /^K^y ,  one 
stroke  at  a  time,  to  locate  the  command  you  want,  and  then  press 

WKmu 

•  If,  while  holding  down  the  down  arrow  key       you  overshoot  the 

command  of  interest,  you  can  hold  down  the  up  arrow  key  to 
move  back  towards  that  command.  Refine  the  selection  with  the 
vertical  keys  i^A^C^r^ ,  one  stroke  at  a  time. 

•  You  can  type  the  first  letter  of  the  command  of  interest,  and  then  use 
the  down  arrow  key        to  locate  that  particular  command.  For 
example,  if  you're  looking  for  the  command  DERIV.  After  activating 
the  help  facility  ([T-oaJ  (W)JIH53  [f/vrc/ij),  type  .    This  will  select 
the  first  of  the  commands  that  start  with  D,  i.e.,  DEGREE.  To  find 
DERIV,  press  ^3?,  twice.   To  activate  the  command,  press  lullil. 
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•     You  can  type  two  or  more  letters  of  the  command  of  interest,  by 
locking  the  alphabetic  keyboard.  This  will  take  you  to  the  command 
of  interest,  or  to  its  neighborhood.  Afterwards,  you  need  to  unlock 
the  alpha  keyboard,  and  use  the  vertical  arrow  keys  i^^Vt/'  to 
locate  the  command,  if  needed.  Press  mm  to  locate  the  to  activate 
the  command.    For  example,  to  locate  the  command  PROPFRAC, 
you  can  use,  one  of  the  following  keystroke  sequences: 

[root J  [nxtJ  [iniliii  [cntek]  [alpha]  [alpha]  (p\  (r\  [alpha]  K^wy)  Ulylji 

[TOa]  (W]||IHi  [CNTER]  [Al£HAj[ALPHA](p](R](0}   [ALPHA]  ^^3?  EES! 
{tool]  [NxFjtSSS  (flW^  [MmA^[ALPHA](P](R](g](P]   [ALPHA]  IEI3S 

See  Appendix  C  for  more  information  on  the  CAS  (Computer  Algebraic 
System).   Appendix  C  includes  other  examples  of  application  of  the  CAS  help 
facility. 
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Appendix  I 
Command  catalog  list 

This  is  a  list  of  all  commands  in  the  command  catalog  ([  r>  J  cm  ).  Those 
commands  that  belong  to  the  CAS  (Computer  Algebraic  System)  are  listed 
also  in  Appendix  H.  CAS  help  facility  entries  are  available  for  a  given 
command  if  the  soft  menu  key  ESH  shov/s  up  when  you  highlight  that 
particular  command.  Press  this  soft  menu  key  to  get  the  CAS  help  facility 
entry  for  the  command.  The  first  fev/  screens  of  the  catalog  are  shov/n  below: 


CATALOG:  COHHAAD^ 

^CH 

X 

1         1         1  ICHnCL 

OK 

CATALOG:  7i1  COHHAnOf 

+ 

< 

1         1         1  ICAACL 

OK 

CATALOG:  COHHAAD^ 

> 
■> 

AECUV 
AE^ 

ACK  |l 

1         1         1  ICAnCL 

OK 

CATALOG:  7i1  COHHAnOf 

ACKALL 

ACOS 

Acosas 

ACO^H 

ADD 

HELPI         1         1  ICAACL 

OK 

CATALOG:  COHHADD^ 

ADDTOREAL 

ALGE 

ALOG 

AHORT 

ADD 

AniHATE  II 

1         1         1  ICADCL 

OK 

CATALOG: 

?i1  COHHADDf 

An; 

APPLV 
ARC 

ARCHIVE 
ARG 

ARIT  II 

HELRl         1         1  ICADCL 

OK 

CATALOG:  COHHADD^ 

ARRY-f 

A^in 

A^inac 

A^inZT 

A^inn 

1         1         1  ICADCL 

OK 

CATALOG:  7^1  COHHADDf 

ASR 

A^^UHE 

ATAD 

ATAn2£ 

ATADH 

ATICK  II 

1         1         1  ICADCL 

OK 

User-installed  library  commands  would  also  appear  on  the  command 
catalog  list,  using  italic  font.  If  the  library  includes  a  help  item,  then  the  soft 
menu  key  Eliiliii  shows  up  when  you  highlight  those  user-created  commands. 
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Appendix  J 

The  AAATHS  menu 

The  MATHS  menu,  accessible  through  the  command  MATHS  (available  in  the 
catalog   cat  ),  contains  the  following  sub-menus: 


Hoth;  H«nu 

CMPLK                          1 1 

MRT 

HYPERBOLIC  1 
IRTEGER  1 
HODULHR  1 
POLVnOHIAL  D 

1         1  1 

ICHnCLl 

OK 

The  CMPLX  sub-menu 

The  CMPLX  sub-menu  contains  functions  pertinent  to  operations  with  complex 
numbers: 


0 

HAin  HERU 

3 

AE£ 

3 

ARC 

H 

conj 

5 

DROITE 

MRT 

FLOOR 

1 

1  1 

icflncL 

OK 

5. DROITE 

fi. FLOOR 

?.IM 

2.  HOD 

3.  DEC 

ID.  RE 

1RT 

1         1         1  ICflnCL 

OK 

These  functions  are  described  in  Chapter  4. 

The  CONSTANTS  sub-menu 

The  CONSTANTS  sub-menu  provides  access  to  the  calculator  mathematical 
constants.  These  are  described  in  Chapter  3: 


:MF 

D.HAin  HERU 

:MF 

H.n 

0. 
0. 

MRTHac^  

1         1  1 

ICAnCLl 

OK 
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The  HYPERBOLIC  sub-menu 

The  HYPERBOLIC  sub-menu  contains  the  hyperbolic  functions  and  their 
inverses.  These  functions  are  described  in  Chapter  3. 


:Ml- 

0 

HAin  HEnu 

0. 

flCOSH 

:MF 

2 

A^inH 

3 

ATAnH 

0. 

:MF 

H 

COSH 

5 

SIAH 

0. 

MRT 

TAHH 

CAnCL  OK 


The  INTEGER  sub-menu 

The  INTEGER  sub-menu  provides  functions  for  manipulating  integer  numbers 
and  some  polynomials.  These  functions  are  presented  in  Chapter  5: 


:Ml- 

:MF 

1 

DIVIS 

2 

EULER 

3 

FACTOR 

0. 

:MF 

H 

CCD 

5 

lECCD 

ts" 

MRT 

ItUOT 

T 

1         1  ICARCL 

OK 

:Ml- 

5.IECCD 

0. 

:MF 

e.ICUOT 

^.IREHAinDER 

S.ISRRIHE? 

:MF 

3.LCH 

lO.nEKTF-RIHE 

ts" 

1RT 

ll.PREVPRIME 

1         1         1  ICAACL 

OK 

The  MODULAR  sub-menu 

The  MODULAR  sub-menu  provides  functions  for  modular  arithmetic  v/ith 
numbers  and  polynomials.  These  functions  are  presented  in  Chapter  5: 


O.HAin  HEAU  1 

2.  DIVH0D 

3.  EKRAnDH0D 
H.FACTORMOD 

MRT 

5.CCDH0D 
C.inVHOD 

1         1  1 

ICARCL 

OK 

H.FACTORMOD 

5.GCDH0D 

C.inVHOD 

?.MODSTO 

S.HULTHOD 

3.P0HH0D 

1RT 

ID.SURTMOD 

1         1         1  ICAACL 

OK 
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The  POLYNOMIAL  sub-menu 

The  POLYNOMIAL  sub-menu  includes  functions  for  generating  and 
manipulating  polynomials.  These  functions  are  presented  in  Chapter  5: 


0 

Hflin  HEnu  1 

2 

FACTOR 

3 

CCD 

:MF 

H 

HERHITE 

5 

LCH 

0. 

MRT 

LEGEHDRE 

CflnCL  OK 


CLEGERDRE 

?.PfiRTFRfiC 

g.PROPFRflC 

S.PTflVL 

:MF 

lO.CUOT 

ll.REHAIRDER 

^. 

1RT 

la.TCHEEVCHEFF 

1         1         1  KfiRCL 

OK 

The  TESTS  sub-menu 

The  TESTS  sub-menu  includes  relational  operators  (e.g.,  ==,  <,  etc.),  logical 
operators  (e.g.,  AND,  OR,  etc.),  the  IFTE  function,  and  the  ASSUME  and 
UNASSUME  commands. 


:MF 

0 

HfllR  HERU 

RffUHE 

2 

URH^^UHE 

3 

> 

:MF 

H 

MRT 

5 

< 

0. 

1 

1  1 

icflncL 

OK 

?.-- 

:MF 

S.f 

3.ARD 

:MF 

10.  OR 

11. ROT  1 

1RT 

CARCL  OK 


Relational  and  logical  operators  are  presented  in  Chapter  21  in  the  context  of 
programming  the  calculator  in  User  RPL  language.  The  IFTE  function  is 
introduced  in  Chapter  3.  Functions  ASSUME  and  UNASSUME  are  presented 
next,  using  their  CAS  help  facility  entries  (see  Appendix  C). 


ASSUME 

ASSUME: 

Assumption  on  a  vari- 
able talgebr.  version^ 
ASSUME tX50> 

X>0 

See:  UHRSSUME 


EKIT  I  ECHO  I  f  EEl  |  £EE2  |  iZZ3  \  HAIR 


UNASSUME 

JHflSSUME: 

^emoyes  all  assump- 
tions on  a  given 
variable 
JHRSSUME<X> 

See:  RSSUME 


EKIT  I  ECHO  I  f  EEl  |  £EE2  |  iZZ3  \  HAIR 
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Appendix  K 
The  AAAIN  menu 

The  MAIN  menu  is  available  in  the  command  catalog.  This  menu  include  the 
following  sub-menus: 


CH£  HEnu 

CflJCFG  1 

HLGE 

DIFF 

HHTH£ 

TRIGO 

MR  I 

SOLVER 

1         1         1  ICflnCL 

OK 

:Hb 

CHS  HEnu 

0. 

:MF 

JOLVER 

CMPLK 

HRIT 

VRL 

:MF 

HHTR 

0. 

1RI 

REHRITE  1 

CflnCL  OK 


The  CASCFG  command 

This  is  the  first  entry  in  the  MAIN  menu.  This  command  configures  the  CAS. 
For  CAS  configuration  information  see  Appendix  C. 

The  ALGB  sub-menu 

The  ALGB  sub-menu  includes  the  following  commands: 


0 

HAin  HEnu 

COLLECT 

DEF 

3 

EKFARD 

H 

FACTOR 

5 

PflRTFRflC 

MR  I 

CUOTE 

i 

i  1 

icfincL 

OK 

S.PHRTFRfiC 

C.tUOTE 

?. STORE 

S.I 

S.SURST 

lO.TEKF-RnD 

MR  I 

ii.unhssiGn  1 

1       1       1  jcfincL 

OK 

These  functions,  except  for  O.MAIN  MENU  and  1 1  .UNASSIGN  are  available 
in  the  ALG  keyboard  menu  (I    J      )-  Detailed  explanation  of  these 
functions  can  be  found  in  Chapter  5.    Function  UNASSIGN  is  described  in 
the  following  entry  from  the  CAS  menu: 


UHflSSIGH: 
Purges  yariable? 
returns  its  yalue 
UHRSSIGH<Y> 

2+y. 

See:  STORE 


EKIT  I  ECHO  I  SEEl  |  SEE2  |  SEE?  |  HAIR 
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The  DIFF  sub-menu 

The  DIFF  sub-menu  contains  the  following  functions: 


MF 
HE 
MR  I 


0  Hflin  HEnu 

3.DIVPC 
H.FOURIER 

e.inrvK 


:MF 

f .PREVHL 

S.RI^CH 

10. SERIES 

:HE 

Il.THRVHR 

12.THYLOR0 

1RI 

i^.TRunc 

1         1         1  ICflnCL 

OK 

These  functions  ore  also  available  through  the  CALC/DIFF  sub-menu  (start  with 

[  <n  jcALc  ).  These  functions  are  described  in  Chapters  13,  14,  and  1  5,  except 

for  function  TRUNC,  which  is  described  next  using  its  CAS  help  facility  entry: 
TRUHC:  I 
Truncation  of  an 
expansion 

TRUHC  t  <  1 +X+X-^2  > -^3 ,  > 
See:  DIVPC  SERIES 


EKIT  I  ECHO  I  f  EEl  |  £EE2  |  SEE3  \  HHIR 


The  MATHS  sub-menu 

The  MATHS  menu  is  described  in  detail  in  Appendix  J. 
The  TRIGO  sub-menu 

The  TRIGO  menu  contains  the  following  functions: 


:Ml- 

0 

HAin  HERU  1 

flcosas 

:HE 

A£IR2C 

3 

A£IR2T 

0. 

:MF 

H 

l\^M\3S 

5 

HALFTAR 

VRL 

MR  I 

6 

SIRCOS 

10 

TCOLLECT 

0. 

:HE 

11 

TEKPARD 

12 

TLIR 

13 

TRIG 

0. 

:MF 

IH 

TRIGCOS 

15 

TRIG^IR 

VRL 

MR  I 

IS 

TRIGTAR 

1 

1         1  ICAnCL 

OK 

:Ml- 

?.TARacsa 

0. 

:HE 

f .TARZfC 

3.TAR2£C2 

ID. TCOLLECT 

0. 

:MF 

11. TEKPARD 

12. TLIR  1 

VRL 

MR  I 

[Ennt^^^^Hl 

These  functions  are  also  available  in  the  TRIG  menu  ([_r^l  trig  ].  Description  of 
these  functions  is  included  in  Chapter  5. 
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The  SOLVER  sub-menu 

The  SOLVER  menu  includes  the  following  functions: 


:Hb 

0 

Hflin  HEnu 

0. 

:MF 
:MF 

MR  I 

DEVOLVE 

2 
3 
H 
5 

ISOL 
LDEC 

LinSOLVE 

SOLVE 

SOLVEVK 

VflL 

0. 

T 

1  1 

ICHnCLl 

OK 

These  functions  are  available  in  the  CALC/SOLVE  menu  (start  with  [  <n  }calc  ). 
The  functions  are  described  in  Chapters  6,  1 1,  and  16. 


The  CMPLX  sub-menu 

The  CMPLX  menu  includes  the  following  functions: 


HE 
MF 
MF 
MR  I 


i.i 

2.  HES 

3.  ARG 

H.conj 

5.DR0ITE 
E. FLOOR 


0 
VRLJ 
0 


CflnCL  OK 


HE 
MF 
MF 
MR  I 


5.DR0ITE 
e. FLOOR 
?.IM 
S.HOD 
3.  REG 
10.  RE 


0. 

VRLJ 
0. 


CflnCL  OK 


The  CMPLX  menu  is  also  available  in  the  keyboard  (ij^lonBtx ).  Some  of  the 
functions  in  CMPLX  ore  also  available  in  the  MTH/COMPLEX  menu  (start  with 
[  <-)  )MTH  Y  Complex  number  functions  are  presented  in  Chapter  4. 


The  ARIT  sub-menu 

The  ARIT  menu  includes  the  following  sub-menus: 

iHEEP 


MF 
MF 


O.HAin  HERU 


2.  NODULAR 

3.  P0LVR0MIflL 


MRIH4 


0. 

VRLJ 

0. 


CAnCL  OK 


The  sub-menus  INTEGER,  MODULAR,  and  POLYNOMIAL  are  presented  in 
detail  in  Appendix  J. 
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The  EXP&LN  sub-menu 

The  EXP&LN  menu  contains  the  following  functions: 


:MP 

Tkl 

o.Hflin  HEnu 

VRL 

:MF 
:MF 

MR  I 

l.TEXPAnD 

2.  Lin 

3.  TSIMP 
H.LnCOLLECT 
E.EKPLn 

0. 
0. 

1         1  1 

icnncLl 

OK 

This  menu  is  also  accessible  through  the  keyboard  by  using  [  <n  )£XPiLN  .  The 
functions  in  this  menu  are  presented  in  Chapter  5. 


The  MATR  sub-menu 

The  MATR  menu  contains  the  following  functions: 


W 
MF 
MF 
MR  I 


o.Hflin  HEnu 


HADHHARD 

REF 
AKH 
AKL 


MF 
MF 

MR  I 


VRLJ 

0 
0 


7.CKA 
f  .AK4 
S.GAU^^ 
ID.SVLVESTER 

11.  PCAR 

12.  JORDAR 


VRU 
0 
0 


:Ml- 

7.CXA 

VRL 

:MF 

f  .AK4 

3.GAU££ 

ID. SYLVESTER 

:MF 

ll.RCAR 

la.JORDAR 

1RI 

These  functions  are  also  available  through  the  MATRICES  menu  in  the 
keyboard  ([  <i ) matrices  ).  The  functions  are  described  in  Chapters  10  and  1 1 , 


The  REWRITE  sub-menu 

The  REWRITE  menu  contains  the  following  functions: 


:Ml- 

0 

HAin  HEnu  1 

VRL 

DISTRIE 

:MF 

2 

EF-SKD 

3 

EKRLR 

0. 

:MF 

H 

EKR2R0H 

5 

FDISTRIR 

0. 

MR  I 

Lin 

:Ml- 

E.Lin 

VRL 

:MF 

?.LnCOLLECT 

S.POHEXRAnD 

s.sincos 

:MF 

ID.SIMPLIFV 

ii.xnuH 

MR  I 

CAnCL  OK 
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These  functions  are  available  through  the  CONVERT/REWRITE  menu  (start 
with  [  *i } CONVERT  j.  The  functions  are  presented  in  Chapter  5,  except  for 
functions  XNUM  and  XQ,  which  are  described  next  using  the  corresponding 
entries  in  the  CAS  help  facility  ((W)(W]C@33 ): 


XNUM 


XQ 


^onyerts  integers  to 
-eals 


0.5 


5ee:  XQ 


EXIT   ECHO   £EE1   £EE2   iZZ3  HHIH 


Tries  to  concert 
approx.  reals  to 
exact  formulas 

See:  XHUM 


EXIT   ECHO   f  EEl   £EE2   iZZ3  HHIH 


1/2 
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Appendix  L 

Line  editor  commands 

When  you  trigger  the  line  editor  by  using  I  *i  Jkry  in  the  RPN  stack  or  in  ALG 
mode,  the  following  soft  menu  functions  ore  provided  (press  [hxt]  to  see  the 
remaining  functions): 


[)EFIHE( 

1+X 
'f (X>=1/(1 

+X-^2 

+^KIP|SKIP-t 

H)EL  1  DEL-f|DEL 

L|  ins  ■ 

DEFIHEt 

1+X  J 
'f  (X>  =  l^(l+X-^2 

SEflRCI GOTO 

1  EDIT  1  -*EG  1  -€nD  |  IFIFO 

+  IKJ=  ^ 

1+X  J 

DEFIHEt 

'f  tx>=i/a+x-^2 

EKEC  1  HALT 

StyHI         1  ITOOLS 

The  functions  are  briefly  described  as  follows: 

<-SKIP:  Skips  characters  to  beginning  of  word. 
SKIP^:  Skips  characters  to  end  of  word. 
<-DEL:  Delete  characters  to  beginning  of  word. 
DEL^:  Delete  characters  to  end  of  word. 
DEL  L:    Delete  characters  in  line. 

INS:     When  selected  inserts  characters  at  cursor  location.  If  not  selected, 
the  cursor  replaces  characters  (overwrites)  instead  of  inserting 
characters. 

EDIT:     Edits  selection. 

^BEG:  Move  to  beginning  of  word. 

^END:  Mark  end  of  selection. 

INFO:    Provides  information  on  Command  Line  editor,  e.g.. 


t  l.in«f: 
Lin«  Size: 

1 
1 
1 
1 

20 

Jth 

Clip 
S<1. 

SiZ«: 
Si2i- 
(KE)  : 
Zi2i- 
ii21- 

IB 
2 

235 
0 

SEHRCI  GOTO 

lEDIT 

-*EG 

1  -€nD 

inro 
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The  items  show  in  this  screen  are  self-explanatory.  For  example,  Xand  Y 
positions  mean  the  position  on  a  line  (X)  and  the  line  number  (Y).  Stk  Size 
means  the  number  of  objects  in  the  ALG  mode  history  or  in  the  RPN  stack. 
Mem(KB)  means  the  amount  of  free  memory.  Clip  Size  is  the  number  of 
characters  in  the  clipboard.  Sel  Size  is  the  number  of  characters  in  the  current 
selection. 

EXEC:  Execute  command  selected. 
HALT:  Stop  command  execution. 

The  line  editor  also  provide  the  following  sub-menus: 

SEARCH:  Search  characters  or  words  in  the  command  line.  It  includes  the 
following  functions: 


3 

Find  nsxt 

H 

R4pl.dc«  Selsitiin 

5 

R4pl.dc«''Find  nixt 

R4pl.dc«  HU 

4: 

? 

Fdft  RiplaCi  flU 

1 

1       1  IcflncLi 

OK 

GOTO:  Move  to  a  desired  location  in  the  command  line.  It  includes  the 
following  functions: 


l.G*-t*  Lin<.. 

a. Got*  P*fiti*n.. 

4: 

DEFINE <:  'Rt:X>=2*X'  > 

1       1       1  icflncLl 

OK 

Style:  Text  styles  that  can  be  used  in  the  command  line: 


::  DEFM'fl(X>=2*X' > 
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The  SEARCH  sub-menu 

The  functions  of  tfie  SEARCH  sub-menu  are: 


Find  :  Use  tfiis  function  to  find  a  string  in  tfie  command  line.  Tfie  input  form 
provided  with  this  command  is  shown  next: 


;<orth  For: 


Replace:  Use  this  command  to  find  and  replace  a  string.  The  input  form 
provided  for  this  command  is: 


FinD  REFLHCE 


;<orth  For: 


Find  next..:  Finds  the  next  search  pattern  as  defined  in  Find 

Replace  Selection:  Replace  selection  with  replacement  pattern  defined  with 

Replace  command. 
Replace/Find  Next:  Replace  a  pattern  and  search  for  another  occurrence. 

The  pattern  is  defined  in  Replace. 
Replace  All:  Replace  all  occurrence  of  a  certain  pattern.  This  command  asks 

for  confirmation  from  the  user  before  replacing  pattern. 
Fast  Replace  All:  Replace  all  occurrences  of  a  certain  pattern  without 
checking  with  the  user. 


The  GOTO  sub-menu 

The  functions  in  the  GOTO  sub-menu  are  the  following: 
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Goto  Line:  to  move  to  a  specified  line.  The  input  form  provided  with  this 
command  is: 


^^»FinD  REPLACE 


Esarch  for: 


Goto  Position:  move  to  a  specified  position  in  the  command  line.  The  input 
form  provided  for  this  command  is: 


Labels:  move  to  a  specified  label  in  the  command  line. 

The  Style  sub-menu 

The  Style  sub-menu  includes  the  following  styles: 

BOL:  Bold 
ITALI:  Italics 
UNDE:  Underline 
DSQ  :  Inverse 

The  command  FONT  allow  the  user  to  select  the  font  for  the  command  editor. 
Examples  of  the  different  styles  are  shown  below: 
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'BOLD" 
"BOLD" 

"BOLD" 

"ITRLICS" 

"ITRLICS" 

"UHDERLIHF" 

'^UHDERLIHE" 


E:DL  I  ^^.t^^  lilMt  IIIZIHI  FOnr  I  EDIT 


"BOLD" 
"INVERSE" 

"USm^^" 


"INVERSE" 

"nam^aea^" 


E:DL  I  ^^AL^  liUicL  liizmi  Fonr  |  edit 
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Appendix  M 
Index 


A 

ABCUV,  5-1 1 
ABS,  1 1-7 
ABS,  3-4 
ABS,  4-6 
ACK,  25-4 
ACKALL,  25-4 
ACQS,  3-6 
ACOSH,  2-62 
ADD,  12-21 
ADD,  8-9 

Additional  character  set,  D-1 
ADDTMOD,  5-12 
Alarm  functions,  25-4 
Alarms,  25-2 
ALG  menu,  5-3 
Algebraic  mode,  1-12 
Algebraic  objects,  5-1 
ALOG,  3-5 

ALPHA  characters,  B-8 
ALPHA  keyboard  lock-unlock,  G-2 
ALPHA-left-shift  characters,  B-9 
ALPHA-right-shift  characters,  B-10 
ALRM  menu,  25-3 
AMORT,  6-32 
AMORTIZATION,  6-1 1 
AND,  19-5 

Angle  between  vectors,  9-16 

Angle  measure,  1-22 

Angle  symbol  (Z),  G-2 

Angle  units,  22-27,  22-29,  22-33 

Angular  measure,  G-2 


ANIMATE,  22-27 
Animating  graphics,  22-26 
Animation,  22-26 
Anti-derivatives,  13-14 
Approximate  CAS  mode,  C-4 
Approximate  vs.  Exact  CAS  mode, 
C-4 

APPS  menu,  F-1 
ARC,  22-21 
AREA  in  plots,  1  2-7 
Area  units,  3-19 

ARG,  4-6 

ARITHMETIC  menu,  5-9 
ASIN,  3-6 
ASINH,  3-9 
ASN,  20-6 
ASR,  1 9-6 
ASSUME,  J-3 
ATAN,  3-6 
ATANH,  3-9 
ATICK,  22-8 

Augmented  matrix,  1 1-30 

AUTO,  22-3 

AXES,  22-14 

AXES,  22-8 

AXL,  9-25 

AXM,  11-15 

AXQ,  1 1-52 

B 

B->R,  19-3 
Bar  plots,  1 2-30 
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BASE  menu,  1 9-1 

Base  units,  3-21 

Batteries,  1-1 

Beep,  1-24 

BEG,  6-32 

BEGIN,  2-26 

Bessel's  equation,  16-55 

Bessel's  functions,  16-55 

Best  data  fitting,  18-12 

Best  polynomial  fitting,  18-51 

Beta  distribution,  1 7-7 

BIG,  12-18 

BIN,  3-2 

Binary  numbers,  19-1 
Binary  system,  1 9-3 
Binomial  distribution,  17-4 
BIT  menu,  1 9-6 
BLANK,  22-32 
BOL,  L-4 
BOX,  12-43 
BOXZ,  12-50 
Building  a  vector,  9-1 2 
BYTE  menu,  19-6 

c 

C->PX,  19-7 
C->R,  4-6 

CALC/DIFF  menu,  1 6-4 
Calculation  witfi  dates,  25-3 
Calculations  witfi  times,  25-4 
Calculator  constants,  3-1 6 
Calculator  modes,  1-12 
CALCULATOR  MODES  input  form, 
C-1 

Calculator  restart,  G-3 
Calculator  system  tests,  G-3 


Calculus,  1  3-1 

Cancel  next  repeating  alarm,  G-3 

Cartesian  representation,  4-1 

CAS  help  facility,  C-10 

CAS  help  facility  listing,  H-1 

CAS  independent  variable,  C-2 

CAS  menu..,  F-6 

CAS  modulus,  C-3 

CAS  settings,  1-24,  C-1 

CASDIR,  2-35  1 6-36 

CASE  construct,  21-51 

CASINFO,  2-35 

Cauchy  equation,  1 6-53 

CEIL,  3-14 

CENTR,  22-7 

Chain  rule,  1  3-6 

Change  sign,  4-2 

Character  set,  D-1 

Character  strings,  23-1 

Characteristic  polynomial,  1 1-44 

Characters  list,  23-3 

CHARS  menu,  23-2 

CHDIR,  2-33 

Chebyshev  polynomials,  1 6-57 

CHINREM,  5-11,  5-19 

Chi-square  distribution,  17-11 

CHOOSE,  21-31 

Choose  box,  21-31 

CHOOSE  boxes,  1-4 

CHR,  23-1 

CIRCL,  1  2-47 

Class  boundaries,  1 8-6 

Class  marks,  1 8-5, 

Classes,  1 8-5 

CLKADJ,  25-3 

Clock  display,  1-29 
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CMD,  2-61 
CMDS,  2-25 
CMPLX  menus,  4-5 
CNCT,  22-14 
CNTR,  12-50 

Coefficient  of  variation,  1  8-5 
COL-,  1 0-20 
COL+,  10-20 
COL^,  10-19 

"Cold"  calculator  restart,  G-3 
COLLECT,  5-5 
Column  norm,  1  1  -8 
Column  vectors,  9-19 
COMB,  1 7-2 
Combinations,  1  7-1 
Command  catalog  list,  1-1 
Complex  CAS  mode,  C-6 
Complex  Fourier  series,  1 6-27 
COMPLEX  mode,  4-1 
Complex  numbers,  2-2  4-1 
Complex  vs.  Real  CAS  mode,  C-6, 
Composing  lists,  8-2 
CON,  10-8 

Concatenation  operator,  8-4 
COND,  11-9 
Condition  number,  1 1-9 
Confidence  intervals,  1  8-22 
Confidence  intervals  for  the 
variance,  1  8-33 
Confidence  intervals  in  linear 
regression,  1  8-52 
Confidence  intervals  in  the 
calculator,  1 8-27 
Conic  curve  graphs,  1  2-21 
Conic  curves,  12-21 
CONJ,  4-6 


CONLIB,  3-29 
Constants  lib,  F-2 
Continuous  self-test,  G-3 
CONVERT,  3-27 
CONVERT  menu,  5-27 
Convolution,  1 6-49 
Coordinate  system,  1-25 
Coordinate  transformation,  14-7 
COPY,  2-26 
COPY,  2-33 

Correlation  coefficient,  18-11 
COS,  3-7 
COSH,  3-9 
Covariance,  1 8-1 1 
CRDIR,  2-40 

Creating  sub-directories,  2-38 
CROSS,  9-1 1 
Cross  product,  9-1 1 
CST,  20-1 
CSWP,  10-21 

Cumulative  distribution  function, 
17-4 

Cumulative  frequency,  1 8-5 
Curl,  1 5-5 
CURS,  2-20 
CUT,  2-26 
CYCLOTOMIC,  5-1 1 
CYLIN,  4-3 

D 

D~>R,  3-14, 
DARCY,  3-31 
DATE,  25-3 
Date  functions,  25-1 
Date  setting,  1-7 
DATE+,  25-3 
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Dates  calculations  25-4 

DESOLVE,  16-7 

DBUG,  21-35 

DET,  11-11 

DDAYS,  25-3 

De-tagging,  21-33 

Debugging  programs,  21-22 

Determinants,  11-12  11-45 

DEC,  19-2 

DIAG^,  10-13 

Decimal  comma,  1-21 

Diagonal  matrix,  10-12 

Decimal  numbers,  1 9-4 

DIFF  menu,  1 6-4 

Decimal  point,  1-20 

DIFFE  sub-menu,  6-31 

Decomposing  a  vector,  9-1 2 

Differential  equation  graph,  1  2-26 

Decomposing  lists,  8-2 

Differential  equations,  1 6-1 

Deep-sleep  shutdown,  G-3 

Differential  equations,  Fourier 

DEFINE,  3-36 

series,  1 6-42, 

Definite  integrals,  13-15 

Differential  equations,  graphical 

DEFN,  12-18 

solutions,  16-60 

DEG,  3-1 

Differential  equations,  Laplace 

Degrees,  1-22 

transform,  1 6-1  7 

DEL,  1  2-47 

Differential  equations,  linear,  1 6-4 

DEL  L,  L-1 

Differential  equations,  non-linear. 

DEL^,  L-1 

16-4 

DELALARM,  25-4 

Differential  equations,  numerical 

Deleting  sub-directories,  2-42 

solutions,  16-60 

DELKEYS,  20-6 

Differential  equations,  slope  fields. 

Delta  function  (Dirac's),  16-15 

16-3 

DEPND,  22-6 

Differential  equations,  solutions. 

DERIV,  1 3-3 

16-2 

DERIV&INTG  menu,  1 3-3 

Differential,  total,  14-5 

Derivative  directional  1 5-1 

Differentials,  13-19 

Derivatives,  13-1,  13-3 

Dirac's  delta  function,  v 

Derivatives  extreme,  13-12 

Directional  derivative,  15-1 

Derivatives  fiigfier  order,  1  3-1  3 

Display  adjustment,  1-2 

Derivatives  step-by-step,  1 3-1 7 

Display  font,  1-26 

Derivatives  implicit  1  3-7 

Display  modes,  1-25 

Derivatives  partial  14-1 

Display  screen  dump,  G-3 

Derivatives  of  equations,  13-6 

DISTRIB,  5-29 

Derivatives  with  d,  1 3-4 

DIV,  15-4 

DERVX,  13-3 

DIV2,  5-1 1 

Page  M-4 


DIV2MOD,  5-1 2 

DIV2MOD,  5-15 

Divergence,  15-4 

DIVIS,  5-10 

DIVMOD,  5-12 

DIVMOD,  5-15 

DO  construct,  21-61 

DOERR,  21-64 

□OUST,  8-12 

DOMAIN,  13-9 

DOSUBS,  8-1 1 

DOT,  9-1 1 

Dot  product,  9-1 1 

DOT-i-  DOT-,  1 2-45 

Double  integrals,  14-6 

DRAW,  12-21,  22-4 

DRAW3DMATRIX,  12-54 

Drawing  functions  programs,  22-22 

DRAX,  22-4 

DROITE,  4-9 

DROP,  9-21 

DTAG,  23-1 

E 

e,  3-16, 
EDIT,  2-33 
EDIT,  L-1 

Editor  commands,  L-1 
EGCD,  5-19 
EGDC,  5-1 1 
EGV,  1 1-46 
EGVL,  1 1  -45 
Eigenvalues,  11-9,  1 1-44 
Eigenvectors,  11-9,  1 1-44 
Electric  units,  3-20 
END,  2-26 


ENDSUB,  8-1 1 
Energy  units,  3-1 9 
Engineering  format,  1-20 
ENGL,  3-29 
Entering  vectors,  9-2 
EPS,  2-35 
EPSXO,  5-23 
EQ,  6-28 

Equation  Writer  (EQW),  2-10 
Equation  writer  properties,  1-28 
Equation  Writer,  Selection  Tree, 
E-1 

Equations,  linear  systems,  11-16 

EQW:  BIG,  2-1 1 

EQW:  CMDS,  2-1 1 

EQW:  CURS,  2-11, 

EQW:  Derivatives,  2-30 

EQW:  EDIT,  2-1 1 

EQW:  EVAL,  2-1 1 

EQW:  FACTOR,  2-1 1 

EQW:  HELP,  2-1  1 

EQW:  Integrals,  2-31 

EQW:  SIMPLIFY,  2-1 1 

EQW:  Summations,  2-28 

ERASE,  12-21,  12-58,  22-4 

ERRO,  21-65 

ERRM,  21-65 

ERRN,  21-64 

Error  trapping  in  programming, 
21-64 

Errors  in  hypothesis  testing,  18-35 

Errors  in  programming,  21-64 

EULER,  5-10 

Euler  constant,  1 6-56 

Euler  equation,  1 6-53 

Euler  formula,  4-1 
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EVAL,  2-5 

Exact  CAS  mode,  C-4 
EXEC,  L-2 

EXP,  3-6 

EXP2POW,  5-29 
EXPAND,  5-5 
EXPANDMOD,  5-1 2 
EXPLN,  5-8 
EXPLN,  5-29 
EXPM,  3-9 

Exponential  distribution,  1 7-7 
Extreme,  1  3-1  2 
Extreme  points,  13-12 
EYE  FT,  22-10 

F 

F  distribution,  1 7-1 2 

FACTOR,  2-10 

Factorial,  3-14 

Factorial  symbol(!),  G-2 

Factoring  an  expression,  2-24 

FACTORMOD,  5-12 

FACTORS,  5-10 

FANNING,  3-31 

Fast  3D  plots,  12-35 

Fast  Fourier  transform,  1 6-49 

Fast  Replace  All,  L-3 

FCOEF,  5-1 1 

FDISTRIB,  5-29 

FFT,  16-49 

Fields,  1 5-1 

File  manager.,  menu..,  F-4 
FILES,  2-32 

Financial  calculations,  6-9 
Find  next..,  L-3 


Finite  arithmetic  ring,  5-14 

Finite  population,  1  8-3 

Fitting  data,  18-10 

Fixed  format,  1-18 

Flags,  24-1 

FLOOR,  3-14 

FOR  construct,  21-59 

Force  units,  3-1 9 

FOURIER,  16-27 

Fourier  series,  1 6-27 

Fourier  series  and  ODEs,  1 6-42 

Fourier  series  for  square  wove,  1  6-40 

Fourier  series  for  triangular  wave, 

16-35 

Fourier  series,  complex,  1 6-27 
Fourier  transforms,  1 6-43 
Fourier  transforms,  convolution, 
16-49 

Fourier  transforms,  definitions, 

16-46 

FP,  3-14 

Fractions,  5-24 

Frequency  distribution,  1  8-5 

Frobenius  norm,  11-17 

FROOTS,  5-1 1 

FROOTS,  5-26 

Full  pivoting,  1 1-34,  1  1-39 

Function  definition,  3-36 

Function  plot,  1  2-2 

FUNCTION  plot  operation,  12-13 

FUNCTION  plots,  1  2-6 

Function,  table  of  values,  1 2-1 7, 

12-26 

Functions,  multi-variate,  14-1 
Fundamental  tfieorem  of  algebra, 
6-7 
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G 

GAMMA,  3-1 5 

Gamma  distribution,  17-6 

GAUSS,  11 -53 

Gaussian  elimination,  1  1-28 

Gauss-Jordan  elimination,  1 1-28 

11-37  11-39 

GCD,  5-11,  5-19 

GCDMOD,  5-12 

Geometric  mean,  1  8-3 

Geometric  mean,  8-1 6 

GET,  10-6 

GETI,  8-1 1 

Global  variable  scope,  21-4 
Global  variable,  21-2 
GOR,  22-32 
Goto  Line,  L-4 
GOTO  menu,  L-2  L-3 
Goto  Position,  L-4 
Grades,  1-22 
Gradient,  15-1 
Graphic  objects,  22-30 
Graphical  solution  of  ODEs,  1 6-60 
Graphics  animation,  22-26 
Graphics  options,  1  2-1 
Graphics  programming,  22-1 
Graphs,  1  2-1 
Graphs  polar,  12-19 
Graphs  conic  curves,  1 2-21 
Graphs  parametric,  1  2-23 
Graphs  differential  equations,  12-26 
Graphs  truth  plots,  1  2-29 
Graphs  bar  plots,  1 2-30 
Graphs  histograms,  1  2-30 
Graphs  scatterplots,  1 2-30 


Graphs  slope  fields,  1  2-34 
Graphs  Fast  3D  plots,  1 2-35 
Graphs  wireframe  plots,  1  2-34 
Graphs  Ps-Contour  plots,  1  2-39 
Graphs  Y-Slice  plots,  12-41 
Graphs  Gridmap  plots,  1  2-42 
Graphs  Pr-Surface  plots,  1  2-43 
Graphs  Zooming,  1  2-49 
Graphs  SYMBOLIC  menu,  12-51 
Graphs  saving,  1 2-7 
GRD,  3-1 

Greek  letters,  D-3,  G-2 
Gridmap  plots,  1 2-42 
GROB,  22-30 

GROB  programming,  22-33 
GROB  menu,  22-31 
GROBADD,  12-52 
Grouped  data,  8-1  8 
Grouped  data  statistics,  8-18 
Grouped  data  variance,  8-1 8 
GXOR,  22-32 

H 

HADAMARD,  11-5 
HALT,  L-2 

Harmonic  mean,  8-15 

HEAD,  8-1 1 

Header  size,  1-29 

Heaviside's  step  function,  16-15 

HELP,  2-26 

HERMITE,  5-1 1,  5-20 

Hermite  polynomials,  1 6-60 

HESS,  15-2 

Hessian  matrix,  1 5-2 

HEX,  19-2 

HEX,  3-1 

Hexadecimal  numbers,  19-7 
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Higher-order  derivatives,  1  3-1  3 
Higher-order  partial  derivatives, 
14-3 

HUBERT,  10-14 
Histograms,  12-30 
HMS-,  25-3 
HMS+,  25-3 
HMS~>,  25-3 
HORNER,  5-1 1,  5-20 
H-VIEW,  1 2-20 

Hyperbolic  functions  graphs,  1 2- 
16 

Hypothesis  testing,  1  8-34 
Hypothesis  testing  errors,  1  8-35 
Hypothesis  testing  in  linear 
regression,  1  8-52 

Hypothesis  testing  in  the  calculator, 
18-42 

Hypothesis  testing  on  variances, 
18-46 

HZIN,  12-50 
HZOUT,  12-50 

I 

i,  3-16 

I/O  functions  menu,  F-2 
UR,  5-28 
lABCUV,  5-1 1 
IBERNOULLi,  5-1 1 
ICHINREM,  5-1 1 
Identity  matrix,  1 0-1 
Identity  matrix,  1 1-6 
iDIV2,  5-1  1 
IDN,  1 0-9 
lEGCD,  5-1 1 

IF.. .THEN. .ELSE.. .END,  21-48 


IF.. .THEN. .END,  21-47 
IFERR  sub-menu,  21-65 
IFTE,  3-35 
ILAP,  16-1 1 

Illumination  units,  3-20 
IM,  4-6 

IMAGE,  11-54 

Imaginary  part,  4-1 
Implicit  derivatives,  1  3-7 
Improper  integrals,  13-21 
Increasing-power  CAS  mode,  C-9 
INDEP,  22-6, 

Independent  variable  in  CAS,  C-2, 
Infinite  series,  13-21,  13-23 
INFO,  22-4 
INPUT,  21-22  , 

Input  forms  programming,  21-21 

Input  forms  use  of  A-1 

Input  string  prompt  programming, 

21-21 

Input-output  functions  menu,  F-2 
INS  ,  L-1 
INT,  13-14 
Integer  numbers,  C-5 
Integers,  2-1 
Integrals,  13-14 
Integrals  definite,  13-15 
Integrals  step-by-step,  1 3-1 7 
Integrals  improper,  13-21 
Integrals  double,  14-6 
Integrals  multiple,  14-6 
Integration  change  of  variable,  1  3-1 9 
Integration  substitution,  1 3-1 8 
Integration  techniques,  13-18 
Integration  by  partial  fractions,  1  3-20 
Integration  by  parts,  13-19 
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Interactive  drawing,  12-43 
Interactive  input  programming,  21-19 
Interactive  plots  with  PLOT  menu, 
22-15 

Interactive  self-test,  G-3 
INTVX,  13-14 
INV,  4-4 
INV,  L-4 

Inverse  cdf's,  17-14 

Inverse  cumulative  distribution 

functions,  1 7-1  3 

Inverse  function  graph,  1  2-1 2 

Inverse  Laplace  transforms,  16-10 

Inverse  matrix,  1 1  -6 

INVMOD,  5-12 

IP,  3-14 

IQUOT,  5-1 1 

IREMAINDER,  5-1 1 

Irrotational  fields,  1 5-5 

ISECT  in  plots,  1 2-7 

ISOL,  6-1 

ISOM,  11-54 

ISPRIME?  ,  5-1 1 

ITALI,  L-4 

J 

Jacobian,  14-7 
JORDAN,  11-47 

K 

KER,  11-55 

Key  Click,  1-23 

Keyboard,  1-10,  B-1 

Keyboard  main  key  functions  B-2 


Keyboard  alternate  key  functions 
B-4 

Keyboard  left-shift  functions  B-5 
Keyboard  right-shift  functions  B-8 
Keyboard  ALPHA  characters  B-9 
Keyboard  ALPHA-left-shift 
characters  B-1 0 
Keyboard  ALPHA-right-shift 
characters,  B-1  2 
Keyboard  ALPHA  function,  1-12 
Keyboard  left-shift  function,  1-12 
Keyboard  main  function,  1-12 
Keyboard  right-shift  function,  1-12 
Kronecker's  delta,  10-1 

L 

LABEL,  12-47 
Labels,  L-4 

LAGRANGE,  5-11,  5-21 
Laguerre's  equation,  16-60 
LAP,  16-11 
LAPL,  15-4 

Laplace  transforms,  1 6-1 0 
Laplace  transforms  inverse,  16-10 
Laplace  transforms  and  ODEs,  1 6-1 7 
Laplace  transforms  theorems,  1 6-1 2 
Laplace's  equation,  15-4 
Laplacian,  1 5-4 
Lost  Stack,  1-24 
LCM,  5-1 1 
LCM,  5-21, 
LCXM,  11-1 
LDEC,  16-4 

Least-square  function,  11-23 
Least-square  method,  1  8-49 
Left-shift  functions,  B-5 
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LEGENDRE,  5-11,  5-22 
Legendre's  equation,  1 6-54 
Length  units,  3-1 8 
LGCD,  5-10 
lim,  13-2 
Limits,  1 3-1 
LIN,  5-5 
LINE,  12-46 

Line  editor  commands,  L-1 
Line  editor  properties,  1-26 
Linear  algebra,  1 1-1 
Linear  applications,  1  1-54 
Linear  differential  equations,  1 6-4 
Linear  regression  confidence 
intervals,  1  8-52 
Linear  regression  fiypothesis 
testing,  1 8-52 

Linear  regression  additional  notes, 
18-49 

Linear  regression  prediction  error, 
18-51 

Linear  system  of  equations,  11-16 

Linearized  relationships,  18-11 

LINSOLVE,  n-40 

LIST,  2-33 

LIST  menu,  8-8 

List  of  CAS  help  facility,  H-1 

List  of  command  catalog,  1-1 

Lists,  8-1 

LN,  3-5 

Ln(X)  graph,  12-9 
LNCOLLECT,  5-5 
LNPl,  3-9, 
Local  variables,  21-2 
LOG,  3-5 

LOGIC  menu,  1 9-5 


Logical  operators,  21-43 
Lower-triangular  matrix,  1  1-49 
LQ,  11-51 

LQ  decomposition,  11-51 
LSQ,  11 -23 
LU,  11-49 

LU  decomposition,  1 1-49 
LVARI,  7-1 2 

M 

Maclaurin  series,  13-21 
MAD,  11-47 
Main  diagonal,  1 0-1 
MAIN  menu,  G-3  K-1 
MAIN/ALGB  menu,  K-1 
MAIN/ARIT  menu,  K-3 
MAIN/CASCFG  command,  K-1 
MAIN/CMPLX  menu,  K-3 
MAIN/DIFF  menu,  K-2 
MAIN/EXP&LN  menu,  K-4 
MAIN/MATHS  menu  (MATHS 
menu),  J-1 

MAIN/MATR  menu,  K-4 
MAIN/REWRITE  menu,  K-4 
MAIN/SOLVER  menu,  K-3 
MAIN/TRIGO  menu,  K-2 
Manning's  equation,  21-19 
MANT,  3-14 
MAP,  8-1 2 
MARK,  1 2-46 
Mass  units,  3-19 
Math  menu  ..,  F-5 
MATHS  menu,  G-3  J-1 
MATHS/CMPLX  menu,  J-1 
MATHS/CONSTANTS  menu,  J-1 
MATHS/HYPERBOLIC  menu,  J-2 
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MATHS/INTEGER  menu,  J-2 

MES,  7-10 

MATHS/MODULAR  menu,  J-2 

Message  box  programming. 

MATHS/POLYNOMIAL  menu,  J-3 

21-37 

MATHS/TESTS  menu,  J-3 

Method  of  least  squares,  1  8-50 

Matrices,  10-1 

MIN,  3-13 

Matrix,  10-1 

Minimum,  1  3-1 2 

Matrix  augmented,  11-30 

Minimum,  14-5 

Matrix  Jordan-circle  decomposition 

MINIT,  7-13 

1  1-54 

MINR,  3-16 

Matrix  "division",  1 1-26 

MITM,  7-12 

Matrix  Writer,  10-2 

MKSISOM,  11-55 

Matrix  factorization,  11-49 

MOD,  3-13 

MATRIX  menu,  1 0-3 

Mode,  18-4 

Matrix  multiplication,  1 1-2 

MODL,  22-1 3 

Matrix  operations,  11-1 

MODSTO,  5-12 

Matrix  quadratic  forms,  11-51 

Modular  arithmetic,  5-1  2 

Matrix  term-by-term  multiplication. 

Modular  inverse,  5-17 

11-5, 

Modular  programming,  22-36 

Matrix  transpose,  10-1, 

MODULO,  2-35 

Matrix  writer,  9-3  , 

Modulus  in  CAS,  C-3 

MATRIX/MAKE  menu,  1 0-3, 

Moment  of  a  force,  9-1  7 

Matrix-vector  multiplication,  1 1-3, 

MSGBOX,  21-31 

MAX,  3-13, 

MSLV,  7-4 

Maximum,  1  3-1  3, 

MSOLV,  7-13 

Maximum,  14-5, 

MTH  menu,  3-7 

MAXR,  3-1 6, 

MTH/LIST  menu,  8-8 

Mean,  18-3, 

MTH/PROBABILITY  menu,  17-1 

Measures  of  central  tendency. 

MTH/VECTOR  menu,  9-10 

18-3 

MTRW,  9-3 

Measures  of  spreading,  1 8-3 

Multiple  integrals,  14-6 

Median,  1  8-3 

Multiple  linear  fitting,  18-56 

MENU,  12-47 

Multi-variate  calculus,  14-1 

Menu  numbers,  20-2 

MULTMOD,  5-1 2 

Menus,  1-3 

Menus  not  accessible  thirough 

N 

keyboard,  G-3 

NDIST,  17-10 
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NEG,  4-6 

Nested  IF...THEN..ELSE..END, 

21-49 

NEW,  2-33 

NEXt  eQuation,  12-6 

NEXTPRIME,  5-1 1 

Non-CAS  commands,  C-1 3 

Non-linear  differential  equations, 

16-  4 

Non-verbose  CAS  mode,  C-7 
NORM  menu,  1 1-6 
Normal  distribution,  17-10 
Normal  distribution  standard, 

17-  17 

Normal  distribution  cdf,  17-10 
NOT,  19-6 
NSUB,  8-12 
NUM,  23-1 
NUM.SLV,  6-14 
NUM.SLV  input  forms,  A-1 
Number  in  bases,  19-1 
Number  format,  1-17 
Numeric  CAS  mode,  C-3 
Numeric  solver  menu,  F-3 
Numeric  vs.  symbolic  CAS  mode, 
C-3 

Numerical  solution  of  ODEs, 
16-60 

Numerical  solution  to  stiff  ODEs, 
16-68 

Numerical  solver,  6-5 
NUMX,  22-10 
NUMY,  22-10 

o 

OBJ->,  9-19 


Objects,  2-1 

objects,  24-1 

OCT,  1 9-2 

Octal  numbers,  3-2 

ODEs  Laplace  transform 

applications,  1 6-1 7 

ODEs  Fourier  series,  1 6-46 

ODEs  Graphical  solution,  16-60 

ODEs  Numerical  solution,  16-60 

ODEs  (ordinary  differential 

equations),  1 6-1 

ODETYPE,  16-8 

OFF,  1-2 

ON,  1-2 

OPER  menu,  11-14 
Operating  mode,  1-13 
Operations  v^itfi  units,  3-25 
Operators,  3-7 
OR,  19-5 
ORDER,  2-33 
Organizing  data,  2-32 
Ortfiogonal  matrices,  1 1-49 
Otfier  cfiaracters,  D-3 
Output  tagging,  21-33 

P 

PA2B2,  5-1 1 

Paired  sample  tests,  1  8-40 
Parametric  plots,  1 2-23 
PARTFRAC,  5-5 
Partial  derivatives,  14-1 
Partial  derivatives  higher-order  14-3 
Partial  derivatives  chain  rule  14-4 
Partial  fractions  integration,  1 3-20 
Partial  pivoting,  1 1-33 
PASTE,  2-26 
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PCAR,  11-44 

Polar  coordinates  double  integrals, 

PCOEF,  5-11,  5-22 

14-9 

PDIM,  22-20 

Polar  plot,  12-19 

Percentiles,  18-14, 

Polar  representation,  4-1 

PERIOD,  2-35  16-35 

POLY  sub-menu,  6-30 

PERM,  1 7-2 

Polynomial  equations,  6-6 

Permutation  matrix,  11-34 

Polynomial  fitting,  1  8-56 

Permutations,  1 7-1 

Polynomials,  5-1  8 

PEVAL,  5-23 

Population,  1 8-3 

PGDIR,  2-43 

POS,  8-1  1 

Physical  constants,  3-28 

POTENTIAL,  15-3 

PICT,  1  2-8 

Potential  function,  15-3  15-6 

Pivoting,  1 1-33 

Potential  of  a  gradient,  1 5-3 

PIX?,  22-22 

Pov/er  units,  3-20 

Pixel  coordinates,  22-25 

POWEREXPAND,  5-29 

Pixel  references,  1 9-7 

POWMOD,  5-1 2 

PIXOFF,  22-22 

PPAR,  12-2,  12-11 

PIXON,  22-22 

Prediction  error  linear  regression. 

Plane  in  space,  9-1 8 

18-51 

PLOT,  12-52 

Pressure  units,  3-20 

PLOT  environment,  1  2-3 

PREVAL,  13-15 

Plot  functions  menu,  F-1 

PREVPRIME,  5-1 1 

PLOT  menu,  22-1 

PRG  menu,  21-5 

PLOT  menu  interactive  plots,  22-1  7 

PRG  menu  sfiortcuts,  21-10 

PLOT  menu  (menu  81),  G-3 

PRG/MODES/KEYS  menu,  20-5 

PLOT  operations,  1 2-5 

PRG/MODES/MENU  menu,  20-1 

Plot  setup,  12-52 

PRIMIT,  2-35 

PLOT  SETUP  environment,  1  2-3 

Probability,  17-1 

PLOT  WINDOW  environment,  1 2-4 

Probability  density  function,  1 7-6 

PLOT/FLAG  menu,  22-14 

Probability  distributions  discrete 

PLOT/STAT  menu,  22-1  1 

17-4 

PLOT/STAT/DATA  menu,  22-12 

Probability  distributions  continuous 

PLOTADD,  12-52 

17-6 

Plots  program-generated,  22-17 

Probability  distributions  for 

Poisson  distribution,  1 7-5 

statistical  inference,  17-9 

Polar  coordinate  plot,  1  2-1 9 

Probability  mass  function,  17-4 
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Program  branching,  21-46 
Program  loops,  21-53 
Program-generated  plots,  22-17 
Programming,  21-1 
Programming  sequential  21-19 
Programming  interactive  input,  21-19 
Programming  input  string  prompt, 

21-  21 

Programming  debugging,  21-22 
Programming  choose  box,  21-31 
Programming  output,  21-33 
Programming  tagged  output,  21-34 
Programming  message  box,  21-37 
Programming  using  units,  21-37 
Programming  error  trapping,  21-64 
Programming  graphics  22-1 
Programming  drawing  functions, 

22-  24, 

Programming  modular,  22-36 
Programming  drawing  commands, 
22-19 

Programming  input  forms,  21-27 
Programming  plots,  22-14 
Programming  with  GROBs,  22-33 
Programs  with  drawing  functions, 
22-24 

PROOT,  5-22 
PROPFRAC,  5-10,  5-25 
Pr-Surface  plots,  1 2-43 
Ps-Contour  plots,  1  2-39 
PSI,  3-15 
Psi,  3-15 

PTAYL,  5-1 1,  5-22 
PTYPE,  22-4 
PUT,  8-10 
PUTI,  10-6 


PVIEW,  22-22 
PX~>C,  1 9-7 

Q 

QR,  11-51 

QR  decomposition,  11-51 
QUADF,  11-52 
Quadratic  form  diagonal 
representation,  1 1-53 
QUIT,  3-30 
QUOT,  5-1 1 
QUOTIENT,  5-23 
QXA,  11-53 

R 

R^B,  1 9-3 

R^C,  4-6 

R^D,  3-14 

R^l,  5-28 

RAD,  3-1 

Radians,  1-22 

Radiation  units,  3-20 

RAND,  17-2 

Random  numbers,  17-2 

RANK,  11-10 

Rank  of  a  matrix,  11-10 

RANM,  10-11 

RCI,  10-25 

RCIJ,  10-26 

RCLKEYS,  20-6 

RCLMENU,  20-1 

RCWS,  1 9-4 

RDM,  10-10 

RDZ,  17-3 

RE,  4-6 
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Real  CAS  mode,  C-6 

Real  numbers,  C-6 

Real  numbers  vs.  Integer  numbers, 

C-6 

Real  objects,  2-1 
Real  part,  4-1 
REALASSUME,  2-35 
RECT,  4-3 
RECV,  2-34, 

Relational  operators,  21-43 

REMAINDER,  5-11,  5-23 

RE  NAM,  2-34 

REPL,  10-12 

Replace,  L-3 

Replace  All,  L-3 

Replace  Selection,  L-3 

Replace/Find  Next,  L-3 

RES,  22-6 

RESET,  22-8 

Restart  calculator,  G-3 

RESULTANT,  5-1 1 

Resultant  of  forces,  9-1 6 

REVLIST,  8-9 

REWRITE  menu,  5-29 

Right-shift  functions,  B-8  , 

Rigorous  CAS  mode,  C-9 

RISCH,  13-14 

RKF,  16-71 

RKFERR,  16-74 

RKFSTEP,  16-72 

RL,  19-6 

RLB,  19-7 

RND,  3-14 

RNRM,  1 1-8 

ROOT,  6-27 

ROOT  in  plots,  1 2-6 


ROOT  sub-menu,  6-27 
ROW-,  1 0-24 
Row  norm,  1 1  -8 
Row  vectors,  9-1 9 
ROW+,  10-24 
ROW^,  10-23 
RPN  mode,  1-13 
RR,  19-6 
RRB,  19-7 

REF.  RREF,  rref,  1  1-47 
RRK,  16-71 
RSBERR,  16-74 
RSD,  11-43 
RSWP,  10-25 
RZZ,  3-1 

s 

Saddle  point,  14-5, 

Sample  correlation  coefficient, 

18-1  1 

Sample  covariance,  1  8-1  1 

Sample  vs.  population,  1  8-5 

Saving  a  graph,  1 2-7 

Scalar  field,  1 5-1 

SCALE,  22-7 

SCALEH,  22-7 

SCALEW,  22-7 

Scatterplots,  1  2-32 

Scientific  format,  1  -20 

Scope  global  variable  21-4 

SEARCH  menu,  L-2  L-3 

Selection  tree  in  Equation  Writer, 

E-1 

SEND,  2-34 
SEQ,  8-1 1 

Sequential  programming,  21-15 
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Series,  1  3-23 

SOLVE  menu,  6-27 

Series  Maclaurin,  1  3-23 

SOLVE  menu  (menu  74),  G-3 

Series  Taylor,  1  3-23 

SOLVE/DIFF  menu,  16-69 

SERIES,  13-23 

SOLVEVX,  6-4 

Series  Fourier,  1 6-27 

SOLVR  menu,  6-28 

Setting  time  and  date,  25-2 

SORT,  2-34 

SHADE  in  plots,  1 2-6 

Special  cfiaracters,  G-2 

Shortcuts,  G-1 

Speed  units,  3-1 9 

SI,  3-29 

SPHERE,  9-15 

SIGMA,  13-14 

SO,  3-5 

SIGMAVX,  13-14 

Square  root,  3-5 

SIGN,  3-14 

Square  v^ave  Fourier  series  1 6-39 

SIGN,  4-6 

SR,  19-6 

SIGNTAB,  12-52  13-10 

SRAD,  11-9 

SIMP2,  5-10,  5-24 

SRB,  1 9-7 

SIMPLIFY,  5-29 

SREPL,  23-3 

Simplify  non-rational  CAS  setting, 

SST,  21-35 

CIO 

Stack  properties,  1  -27 

Simplifying  an  expression,  2-23 

Standard  deviation,  1 8-4 

SIN,  3-7 

Standard  format,  1-17 

Single-variable  statistics,  1  8-2 

Standard  normal  distribution,  1 7- 

Singular  value  decomposition,  1 1-8 

17, 

SINH,  3-9 

START  ..STEP  construct,  21-58 

SIZE,  8-10 

START... NEXT  construct,  21-54 

SIZE,  10-7 

STAT  menu,  18-15 

SKIP^,  L-1 

STAT  menu  (menu  96),  G-3 

SL,  1 9-6  , 

Statistical  inference  probability 

SLB,  19-7 

distributions,  1 7-9 

Slope  fields,  1  2-34 

Statistics,  18-1 

Slope  fields  for  differential 

Step  function  (Heaviside's  ),  16-15 

equations,  1 6-3 

Step-by-step  CAS  mode,  C-7 

SLOPE  in  plots,  1 2-7 

Step-by-step  derivatives,  13-16 

SNRM,  11-7 

Step-by-step  integrals,  13-16 

SOFT  menus,  1-3 

STEQ,  6-14 

SOLVE,  5-5 

Stiff  differential  equations,  16-71 

SOLVE,  6-2,  7-1, 

Stiff  ODE,  1 6-68 
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Stiff  ODEs  numerical  solution,  16-69 

Strings,  23-1 

STO,  2-46 

STOALARM,  25-4 

STOKEYS,  20-6 

STREAM,  8-12 

String  concatenation,  23-2 

Student  t  distribution,  1 7-1 1 

STURM,  5-1 1 

STURM AB,  5-1 1 

STWS,  1 9-4 

Style  menu,  L-4 

SUB,  10-11 

Sub-directories  creating,  2-38 
Sub-directories  deleting,  2-42 
Sub-expressions,  2-17 
SUBST,  5-5 
SUBTMOD,  5-1 2 
SUBTMOD,  5-16 
Sum  of  squared  errors  (SSE), 
18-62 

Sum  of  squared  totals  (SST),  1 8-62, 
Summary  statistics,  1 8-1 3 
SVD,  11-50 
SVL,  11-50 
SYLVESTER,  11-53 
SYMB/GRAPH  menu,  12-52 
Symbolic  CAS  mode,  C-3 
SYMBOLIC  menu,  12-51 
Synthetic  division,  5-26, 
SYST2MAT,  11-42, 
System  flag 

(EXACT/APPROX),  G-1, 

System  flag  1 1 7  (CHOOSE/SOFT), 

1-4,  G-2, 

System  flag  95  (ALG/RPN),  G-1 


system  flags,  24-3 
System  level  operation,  G-3 
System  of  equations,  11-16 
System  tests,  G-3 

T 

Table,  12-17,  12-26 
TABVAL,  12-52,  13-9 
TABVAR,  12-52,  13-11 
Tagged  output  programming, 

21-  34 
TAIL,  8-1 1 
TAN,  3-7 
TANH,  3-9 

Taylor  polynomial,  1 3-23 
Taylor  series,  1 3-24 
TAYLR,  13-25 
TAYLRO,  13-24 
TCHEBYCHEFF,  5-24 
Tchebycheff  polynomials,  1 6-58 
TDELTA,  3-31 

Techiniques  of  integration,  1  3-1 8 
Temperature  units,  3-20 
TEXPAND,  5-5 
Text  editor.,  menu,  F-5 
Three-dimensional  plot  programs, 

22-  15 

Three-dimensional  vector,  9-1 3 
TICKS,  25-3 
Time  setting  25-2 
TIME,  25-3 

Time  &  dote...  menu,  F-3 
Time  functions,  25-1 
TIME  menu,  25-1 
Time  setting,  1  -7 
TIME  tools,  25-2 
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Time  units,  3-1 9 

Times  calculations  25-4 

TINC,  3-32 

TITLE,  7-15 

TUNE,  12-46 

TUNE,  22-20 

TMENU,  20-1 

TOOL  menu,  1-6 

TOOL  menu:  CASCMD,  1-7 

TOOL  menu:  CLEAR,  1-7 

TOOL  menu:  EDIT,  1-6 

TOOL  menu:  HELP,  1-7 

TOOL  menu:  PURGE,  1-7 

TOOL  menu:  RCL,  1-7 

TOOL  menu:  VIEW,  1-7 

Total  differential,  14-5 

TPAR,  12-18 

TRACE,  11-13 

TRAN,  11-14 

Transforms  Laplace,  16-10 

Transpose,  10-1, 

Triangle  solution,  7-10, 

Triangular  wave  Fourier  series  1 6-35, 

TRIG  menu,  5-8, 

Trigonometric  functions  grapfis, 

12-16, 

TRN,  10-8, 

TRNC,  3-14 

Trutfi  plots,  1 2-29 

TSTR,  25-3 

TVM  menu,  6-32 

TVMROOT,  6-32 

Two-dimensional  plot  programs, 

22-14 

Two-dimensional  vector,  9-12 
TYPE,  24-2 


u 

UBASE,  3-21 
UFACT,  3-27 
UNASSIGN,  K-1 
UNASUMME,  J-3 
UNDE,  L-4 
UNDO,  2-61 
UNIT,  3-29 
Unit  prefixes,  3-24 
Units,  3-17 

Units  in  programming,  21-37 
Upper-triangular  matrix,  11-41, 
User  RPL  language,  21-1 
User-defined  keys,  20-1 
Using  input  forms,  A-1, 
UTILITY  menu  (menu  1 1 3),  G-3 
UTPC,  17-12 
UTPF,  1 7-1 3 
UTPN,  17-10 
UTPT,  17-11 
UVAL,  3-27 

V 

V^,  9-12 
VALUE,  3-30 
VANDERMONDE,  10-14 
VANDERMONDE,  1 8-59 
Variable  scope,  21-4 
Variables,  26-1 

Variance  confidence  intervals,  1 8-33 

Variance,  1  8-4 

Variance  inferences,  18-47 

Vector  building,  9-1  2 

Vector  analysis,  1 5-1 
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Vector  elements,  9-7 
Vector  fields,  15-1 
Vector  fields  curl,  1 5-5 
Vector  fields  divergence  1 5-4 
VECTOR  menu,  9-10 
Vector  potential,  1 5-6 
Vectors,  9-1 

Verbose  CAS  mode,  C-6 

Verbose  vs.  non-verbose  CAS 

mode,  C-7 

VIEW  in  plots,  1 2-6 

Viscosity,  3-20 

Volume  units,  3-1 9 

VPAR,  12-44 

VPAR,  22-10 

VPOTENTIAL,  15-6 

VTYPE,  24-2 

V-VIEW,  12-20 

VX,  2-35 

VX,  5-20 

VZIN,  1 2-50 

w 

"Warm"  calculator  restart,  G-3 
Weber's  equation,  1 6-59 
Weibull  distribution,  17-7 
Weighted  average,  8-17 
WHILE  construct,  21-62 
Wireframe  plots,  1  2-37 
Wordsize,  19-4 

X 

XCOL,  22-13 
XNUM,  K-5 
XOR,  1 9-5 


XPON,  3-14 
XQ,  K-5 
XRNG,  22-6 
XROOT,  3-5 
XSEND,  2-34 
XVOL,  22-10 
XXRNG,  22-10 
XYZ,  3-1 

Y 

YCOL,  22-13 
YRNG,  22-6 
Y-Slice  plots,  12-41 
YVOL,  22-10 
YYRNG,  22-10 


ZAUTO,  12-50 
ZDECI,  12-50 
ZDFLT,  12-50 
ZEROS,  6-4 
ZFACT,  12-49 
ZFACTOR,  3-31 
ZIN,  12-49 
ZINTG,  12-51 
ZLAST,  12-49 
ZOOM,  12-19 
Zooming,  1  2-49 
ZOUT,  12-49 
ZSQR,  12-51 
ZTRIG,  12-51 
ZVOL,  22-10 

Other  characters 

I,  1 7-2 
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%,  3-12 

^END,  L-1 

%CH,  3-12 

^GROB,  22-31 

%T,  3-1 2 

^HMS,  25-3 

Z,  2-28 

^LCD,  22-32 

SDAT,  18-5, 

^LIST,  9-23 

ALIST,  8-9 

^ROW,  10-22 

SLIST,  8-9 

^SKIP,  L-1 

nUST,  8-9 

^STK,  3-30 

EPAR,  22-13 

^STR,  23-1 

^ARRY,  9-21 

^TAG,  21-33 

^ARRY,  9-6 

^TAG,  23-1 

^BEG,  L-1 

^TIME,  25-3 

^COL,  10-18 

^UNIT,  3-27 

^DATE,  25-3 

^V2,  9-1 2 

^DEL,  L-1 

^V3,  9-1 3 

^DIAG,  10-13 

Limited  Warranty 

hp  48gll  graphing  calculator;  Warranty  period:  12  months 

1.  HP  warrants  to  you,  the  end-user  customer,  that  HP  hardware, 
accessories  and  supplies  will  be  free  from  defects  in  materials  and 
workmanship  after  the  date  of  purchase,  for  the  period  specified 
above.  If  HP  receives  notice  of  such  defects  during  the  warranty  period, 
HP  will,  at  its  option,  either  repair  or  replace  products  which  prove  to 
be  defective.  Replacement  products  may  be  either  new  or  like-new. 

2.  HP  warrants  to  you  that  HP  software  will  not  fail  to  execute  its 
programming  instructions  after  the  date  of  purchase,  for  the  period 
specified  above,  due  to  defects  in  material  and  workmanship  when 
properly  installed  and  used.  If  HP  receives  notice  of  such  defects 
during  the  warranty  period,  HP  will  replace  software  media  which 
does  not  execute  its  programming  instructions  due  to  such  defects. 

3.  HP  does  not  warrant  that  the  operation  of  HP  products  will  be 
uninterrupted  or  error  free.  If  HP  is  unable,  within  a  reasonable  time,  to 
repair  or  replace  any  product  to  a  condition  as  warranted,  you  will  be 
entitled  to  a  refund  of  the  purchase  price  upon  prompt  return  of  the 
product  with  proof  of  purchase. 

4.  HP  products  may  contain  remanufactured  parts  equivalent  to  new  in 
performance  or  may  have  been  subject  to  incidental  use. 

5.  Warranty  does  not  apply  to  defects  resulting  from  (a)  improper  or 
inadequate  maintenance  or  calibration,  (b)  software,  interfacing,  parts 
or  supplies  not  supplied  by  HP,  (c)  unauthorized  modification  or  misuse, 
(d)  operation  outside  of  the  published  environmental  specifications  for 
the  product,  or  (e)  improper  site  preparation  or  maintenance. 

6.  HP  MAKES  NO  OTHER  EXPRESS  WARRANTY  OR  CONDITION 
WHETHER  WRITTEN  OR  ORAL.  TO  THE  EXTENT  ALLOWED  BY  LOCAL 
LAW,  ANY  IMPLIED  WARRANTY  OR  CONDITION  OF 
MERCHANTABILITY,  SATISFACTORY  OUALITY,  OR  FITNESS  FOR  A 
PARTICULAR  PURPOSE  IS  LIMITED  TO  THE  DURATION  OF  THE 
EXPRESS  WARRANTY  SET  FORTH  ABOVE.  Some  countries,  states  or 
provinces  do  not  allow  limitations  on  the  duration  of  an  implied 
warranty,  so  the  above  limitation  or  exclusion  might  not  apply  to  you. 
This  warranty  gives  you  specific  legal  rights  and  you  might  also  have 
other  rights  that  vary  from  country  to  country,  state  to  state,  or  province 
to  province. 
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7.  TO  THE  EXTENT  ALLOWED  BY  LOCAL  LAW,  THE  REMEDIES  IN  THIS 
WARRANTY  STATEMENT  ARE  YOUR  SOLE  AND  EXCLUSIVE 
REMEDIES.  EXCEPT  AS  INDICATED  ABOVE,  IN  NO  EVENT  WILL  HP 
OR  ITS  SUPPLIERS  BE  LIABLE  FOR  LOSS  OF  DATA  OR  FOR  DIRECT, 
SPECIAL,  INCIDENTAL,  CONSEQUENTIAL  (INCLUDING  LOST  PROFIT 
OR  DATA),  OR  OTHER  DAMAGE,  WHETHER  BASED  IN  CONTRACT, 
TORT,  OR  OTHERWISE.  Some  countries.  States  or  provinces  do  not 
allow  the  exclusion  or  limitation  of  Incidental  or  consequential  damages, 
so  the  above  limitation  or  exclusion  may  not  apply  to  you. 

8.  The  only  warranties  for  HP  products  and  services  are  set  forth  in  the 
express  warranty  statements  accompanying  such  products  and  services. 
HP  shall  not  be  liable  for  technical  or  editorial  errors  or  omissions 
contained  herein. 

FOR  CONSUMER  TRANSAQIONS  IN  AUSTRALIA  AND  NEW  ZEALAND:  THE 
WARRANTY  TERMS  CONTAINED  IN  THIS  STATEMENT,  EXCEPT  TO  THE  EXTENT 
LAWFULLY  PERMIHED,  DO  NOT  EXCLUDE,  RESTRICT  OR  MODIFY  AND  ARE  IN 
ADDITION  TO  THE  ^\ANDATORY  STATUTORY  RIGHTS  APPLICABLE  TO  THE 
SALE  OF  THIS  PRODUQ  TO  YOU. 

Service 

Europe 


Austria 

+43-1-3602771203 

Belgium 

+32-2-7126219 

Denmark 

+45-8-2332844 

Eastern  Europe 

countries 

+420-5-41422523 

Finland 

+358-9-640009 

France 

+33-1-49939006 

Germany 

+49-69-95307103 

Greece 

+420-5-41422523 

Holland 

+31-2-06545301 

Italy 

+39-02-75419782 

Norway 

+47-63849309 

Portugal 

+351-229570200 

Spain 

+34-915-642095 

Sweden 

+46-851992065 

Switzerland 

+41-1-4395358  (German 
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Asia  Pacific 


L.America 


N.America 


+41-22-8278780  (French) 

+39-02-75419782  (Italian) 

Turkey 

+420-5-41422523 

UK 

+44-207-4580161 

Czech  Republic 

+420-5-41422523 

South  Africa 

+27-11-2376200 

Luxembourg 

+32-2-7126219 

Other  European 

countries 

+420-5-41422523 

^■Telephone  number^^^^^^H 

Australia 

+61-3-9841-521 1 

Singapore 

+61-3-9841-521 1 

Country :  hbHB 

Telephone  numbers^^sHM^ 

Argentina 

0-810-555-5520 

Brazil 

Sao  Paulo  3747-7799;  ROTC 

0-800-157751 

Mexico 

Mx  City  5258-9922;  ROTC 

01-800-472-6684 

Venezuela 

0800-4746-8368 

Chile 

800-360999 

Columbia 

9-800-114726 

Peru 

0-800-10111 

Central  America  & 

Caribbean 

1-800-711-2884 

Guatemala 

1-800-999-5105 

Puerto  Rico 

1-877-232-0589 

Costa  Rica 

0-800-011-0524 

Country JHI^B 

^^Mb  Telephone  numbersJHlBBHi 

U.S. 

1 800-HP  INVENT 

Canada 

(905)  206-4663  or  800-  HP 

INVENT 

ROTC  =  Rest  of  the  country 
Please  logon  to  http://www.hp.com  for  the  latest  service  and  support 
information. 
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Regulatory  information 

This  section  contains  information  that  shows  how  the  hp  48gll  graphing  calculator  complies  with 
regulations  in  certain  regions.  Any  modifications  to  the  calculator  not  expressly  approved  by 
Hewlett-Packard  could  void  the  authority  to  operate  the  48gll  in  these  regions. 

USA 

This  calculator  generates,  uses,  and  can  radiate  radio  frequency  energy  and  may  interfere  with 
radio  and  television  reception.  The  calculator  complies  with  the  limits  for  a  Class  B  digital  device, 
pursuant  to  Part  1 5  of  the  FCC  Rules.  These  limits  are  designed  to  provide  reasonable  protection 

against  harmful  interference  in  a  residential  installation. 

However,  there  is  no  guarantee  that  interference  will  not  occur  in  a  particular  installation.  In  the 
unlikely  event  that  there  is  interference  to  radio  or  television  reception(which  can  be  determined 
by  turning  the  calculator  off  and  on),  the  user  Is  encouraged  to  try  to  correct  the  interference  by 
one  or  more  of  the  following  measures: 

■  Reorient  or  relocate  the  receiving  antenna. 

■  Relocate  the  calculator,  with  respect  to  the  receiver. 
Connections  to  Peripheral  Devices 

To  maintain  compliance  with  FCC  rules  and  regulations,  use  only  the  cable  accessories  provided. 

Canada 

This  Class  B  digital  apparatus  complies  with  Canadian  ICES-003.  Cet  apparell  numerique  de  la 
classe  B  est  conforme  a  la  norme  NMB-003  du  Canada. 

Japan 

:i©gsi* ,  mmmwmmmmimm  §  ±*iijtisii*(vcci)©»¥ 

Disposal  of  Waste  Equipment  by  Users  in  Private  Household  in  the  European 
Union 

XThls  symbol  on  the  product  or  on  its  packaging  indicates  that  this  product  must 
not  be  disposed  of  with  your  other  household  waste.  Instead,  it  is  your 
responsibility  to  dispose  of  your  waste  equipment  by  handing  it  over  to  a 
designated  collection  point  for  the  recycling  of  waste  electrical  and  electronic 
equipment.  The  separate  collection  and  recycling  of  your  waste  equipment  at  the 
time  of  disposal  will  help  to  conserve  natural  resources  and  ensure  that  it  is 
^^^^^^      recycled  in  a  manner  that  protects  human  health  and  the  environment.  For  more 
information  about  where  you  can  drop  off  your  waste  equipment  for  recycling,  please  contact 
your  local  city  office,  your  household  waste  disposal  service  or  the  shop  where  you  purchased  the 
product. 
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